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PREFACE 


This document is intended for use by system engineers, system integrators, 
and service technicians. It provides the information needed to install, con- 
figure, program, operate, and maintain the NCR ADP-47 Disk Controller. 
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CHAPTER 1 


GENERAL DESCRIPTION 


INTRODUCTION 


The NCR ADP-47 Disk Controller is a SCSI (Small Computer System 
Interface) device incorporating the NCR (SDC) SCSI Disk Controller and 
the NCR (DIF) Drive Interface VLSI chips. The controller provides a 
high level interface between the SCSI bus and ESDI (Enhanced Small 
Device Interface) disk drive(s). The controller provides electronic control 
of the SCSI bus, automatic bus protocol handling, and retry/ECC 
correction for fixed disk drives. . 


The NCR ADP-47 Disk Controller is a high performance, 
very-low-overhead disk drive controller. The disk controller works with 
high performance disk drives in single or multi-tasking user applications. 


PURPOSE OF PRODUCT 


The controller operates with either single-initiator or multiple-initiator 
systems. It provides the host with access to varied, multiple disk units. 
Listed below are the two different controller configurations. 


e ADP-47-03 ESDI with single-ended SCSI. 
e ADP-47-04 ESDI with differential SCSI. 
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GENERAL DESCRIPTION 


FEATURE SUMMARY 


. Industry Standard SCSI Interface - ANSI X3.131-1986 (Single Ended or 
Differential) : 
Industry Standard ESDI Fixed Disk Drive Interface 
SCSI Common Command Set (CCS) 
I/O Performance Features . 
e Minimal controller overhead time 
e Dual rotating sector buffers 
e Programmable sector interleave, track skew-factor and cylinder 
skew-factor 
e Automatic sector-level defect handling 
e SCSI implementation includes arbitration, disconnection, 
re-selection, and parity 
e 1.6 Mbyte nominal SCSI bus transfer rate 
e Consecutive multi-sector transfer with one-to-one interleave over 
track boundaries (entire cylinder transfer without losing a 
revolution) 
Rotational Position Sensing (RPS) for just-in-time re-connection 
Programmable bus disconnect options 
Logical block addressing 
Implied seek 
Seek overlap capability 


Data Integrity and Test Features 
e 56-bit ECC corrects up to 11 bit burst errors 
e Parity throughout controller to insure data integrity 
e Self diagnostics 
e Extensive list of diagnostic commands 


Fixed Disk Drive Support 
e Drive parameter selection and geometry parameters obtained 
from the drive ; 
Hard- and soft-sector support 
Alternate sector-per-track option 
Sector size - 256, 512 or 1024 bytes 
Number of drives - 4 maximum 
Number of heads - 16 maximum 
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ESDI Features 


e The following general-configuration options are supported. 
e Formal speed-tolerance gap 

Track-offset option 

Data-strobe-offset option 

Rotational-speed tolerance 

Transfer rate >5 MHz 

Spindle-motor-control option 

Head-switch time 

Hard sectors 

Soft sectors 


e The following specific configuration options are supported. 
e Number of fixed cylinders 
Number of fixed heads (16 maximum) 
Minimum unformatted bytes per track 
Minimum unformatted bytes per sector (hard sector only) 
Number of sectors per track (hard sectors only) 
Minimum bytes in ISG field 
Minimum bytes in PLO field 
Number of bytes vendor unique status 
Vendor identification 


Single-ended Signal Transfer | 
The controller permits single-ended signal transfer over the SCSI bus. 
Differential Signal Transfer . 
The controller permits differential signal transfer over the SCSI bus. 
SCSI Arbitration 
The controller can be used with hosts that use arbitration (multiple 
hosts). 
Parity 
The controller provides a hardware option to enable or disable SCSI 
data bus parity. 
SCSI Messages 
The controller sends and accepts those SCSI messages required for the 
SCSI features that are supported. It sends only the Command 
Complete message to a host that does not support other messages. 
Extended messages, which include Modify Data Pointer, Synchronous 
Data Transfer Request, and Extended Identify are not supported. The 
controller does not send the Linked Command Complete message 
because Linked Commands are not supported. 
Asynchronous Data Transfer 
The controller supports asynchronous data transfer. 
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Programmable Interleave 
An interleave (lacing) factor up to the track capacity can be specified 
in the Format Unit command. An interleave factor of 1 is permitted, 
but a factor of 2 is required to access logically sequential blocks in a 
single revolution. 

Implied Seek 
A Seek command is implied in every data transfer command; heads 
are automatically positioned. In a multiple-block access that crosses 
track or cylinder boundaries, movement to the next track or cylinder 
is automatic. 

Hard Reset Option 

_ The controller uses the “hard” reset option in response to the Reset 

signal (RST). Reservations are terminated, and the Mode Select 
conditions are returned to the default values. System and application 
software have the responsibility for recovery from the Reset condition. 
This may include re-issuing Reserve and Mode Select commands, 
re-positioning the unit, and then re-issuing the last command or series 
of commands. 

Error Handling 
The controller automatically performs retries of a Read operation. A 
recoverable Read error on a fixed disk is automatically corrected by 
the ECC. 

Device Independence 
Logical Unit Numbers (LUNs) are independent of physical port 
numbers. All accesses specify LUNs. 

Defect Handling 
The controller automatically assigns and maintains alternate tracks 
for media defects. 

Fault Detection 
Extended fault detection is available from the interface as a status 
message. 

Shielded or Non-shielded Connectors 
The use of shielded or non-shielded connectors is dependent upon 
specific product requirements. 

Performance Rates 
The maximum rate of data transfer is 1.6 MB/s. The maximum 
throughput of the controller depends upon the interleave specified in 
formatting the disk unit. The controller is capable of transferring one 
track per revolution with an interleave of one. 
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GENERAL DESCRIPTION 


Figure 1-1 is a block diagram of the controller. 


1 
1 
1 
I 
I 
1 
i 
I 
1 
1 
1 
1 
1 
1 
i 
1 
i 
! 
L 


SOC Chip 


Externai Control! Block 


Detection” 
Correction 


Butter 8 il 
‘ Buffer 
ane Options 


ButferAt | 


a 


Suffer Out 


ESO! Controiler Board 


Figure 1-1 ADP-47 block diagram 


External 
Disk 
Interface 


Clock Data 
Synchronization 


1-5 


INTERFACES 


CHAPTER 2 


INTERFACES 


HARDWARE INTERFACE 


The disk controller complies with the electrical, logical, timing, and 
protocol requirements specified in the increased performance “SCSI 
Specification ANSI X3.131-1986” documentation. The controller has the 
following SCSI options: 


Single-ended or differential drivers and receivers 
Parity checking 

Arbitration 

Message capability 

Disconnect/reconnect capability 


HOST SYSTEM !/O 
: The controller interfaces to the host system through the SCSI bus that 
operates at a nominal rate of 1.6 Mbytes per second. 


The SCSI interface uses logical addressing for the data structures. 
Data is addressed as logical blocks up to the maximum number specified 
by the subsystem controller for each device. 


The SCSI architecture handles connections for up to eight devices 
using a maximum cable length of 19.68 feet (6 meters) for Single-ended or 
82.02 feet (25 meters) for Differential. The interface protocol includes 
provision for the connection for multiple Initiators (SCSI bus devices that 
initiate operations) and Targets (SCSI bus devices that respond to a 
request to perform an operation). 
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| INTERFACES 


Arbitration is built into the SCSI architecture. The Arbitration Phase 
takes place when multiple contenders request access to a shared system 
device. Arbitration is the period of actual bus occupancy when the 
requesting access occurs. Before arbitrating for the bus, an Initiator 
ensures that the bus is available, or waits until the bus is released. The 
SCSI bus device that wins arbitration gains interface control through a 
logical priority system. 


Actual data transfer over the SCSI bus is accomplished with a 
Request/Acknowledge handshake scheme. 


ESDI DISK DRIVE I/O 


The controller transfers control signals to the fixed disk drive(s), and 
receives status information from them over the daisy-chained, 34-pin 
command cable. Radial, 20-pin data cable provides the receive and 
transmit data capability to and from the fixed disk drive(s). 


The four fixed drives supported by the controller are addressed as 
logical units 00, 01, 02, and 03. 


INTERFACES 


SOFTWARE INTERFACE 
The controller interfaces to the host system through the SCSI bus. The 
host Initiator originates the SCSI commands and selects a Target 
(controller) in the Selection Phase. The controller requests the additional 
transfer of command, data, status, or message information required to 
complete the originally-initiated command. Upon command completion, 
the controller sends a Command Complete message to the host. 


SCSI protocol allows the controller to accept only one command at a 
time for each host/logical unit combination. However, the controller 
accepts up to eight different commands for different hosts/logical units. 
The command priority is as follows: 


@ Highest priority: 
e Inquiry command 


e Next to highest priority, all commands except: 
e Inquiry command 
e Format Unit command 
e Send Diagnostic command 
e Receive Diagnostic command 


e Next to lowest priority: 
e Format Unit command 


@ Lowest priority: 
e Send Diagnostic Result command 
e Receive Diagnostic Result command 


SCS/ CCS COMMANDS 


CHAPTER 3 


SCSI CCS COMMANDS 


INTRODUCTION 


The controller supports the following SCSI Common Command Set (CCS) 
commands. The number preceding the command is the hexadecimal 
operation code. The operation code is always byte 00 in the command 
descriptor for each CCS command. 


@ (00) Test Unit Ready 
@ (01) Rezero Unit 

e (03) Request Sense 

@ (04) Format Unit 

e (07) Reassign Blocks 
e (08) Read Data 

e (0A) Write Data 

e (0B) Seek 

(12) Inquiry 

(15) Mode Select 

(16) Reserve 

(17) Release 

(1A) Mode Sense 

(1C) Receive Diagnostic Result 
(1D) Send Diagnostic 
(25) Read Capacity 
(28) Read Extended 
(2A) Write Extended 
(2B) Seek Extended 
(2E) Write and Verify 
e (2F) Verify 

® (37) Read Defect Data 
e (3B) Write Buffer 

e (3C) Read Buffer 
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SCS/ CCS COMMANDS 


TEST UNIT READY (00) 


This command returns a Completion Status with no Check Condition if 
_ the selected logical unit is powered on and ready. (Refer to the 

“Completion Status” and the “SCSI Messages” sections.) This is not a 

request for unit self test. Figure 3-1 shows the command descriptor. 


a te ee ree are ee ee ee ey ee ae te a DO ee SE ND SE SD DN SS SD SD SD SD SO TY SD ED EY GD SED SE eS 
Se ee re ae ee re ee ee ES TS SD EN NS ES SS ES A TT LS SS A A AY ee 


| BIT | 

bP ES NE Be Sie Ne Bes a eg A Op 
BYTE 3 =SSS=SS=SS=S=SSSSSSSSSSSSSSSSSSSSSSSSSSSSS=S=SSS= 
OO. Uh 26. Poe he Oy ah oe IS es. OT a ent 
Ol | Logical Unit | Reserved | 

| Number (LUN) | | 
02 =| Reserved | 
os | Reserved 
04 =| Reserved | 
05 =| Reserved | 


Figure 3-1 Test Unit Ready command descriptor 


The host expects a fast response for this command. This command 
does not use the Logical Block Address and Number of Blocks fields. Both 
fields are zero-filled. | 
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REZERO UNIT (01) 


This command causes the controller to move the heads of the specified 
unit to cylinder zero. The controller uses this command primarily to set 
the unit to a specific known state. Figure 3-2 shows the command 


descriptor. 

thine BIT | 

TG) Be ee ee eo ee ge 
BYTE =S=Sss=sssSssssssssssssssssssssssssasssssssSsass= 
OO. a Or. Wie SOs IO Ue ae a ED VOL =. a Ee 
o. |LUN | Reservea. | 
go, sp oe Seceracag re 
o | ©. Reserved | | 
Sir (Gs Reserved’ 
Qasr ees ee | 


ce te ee re are as re a es cer ee ee cee ne ee ee oe ete A SAS SD A SD AS ce SEY Si EY RO ST ES 
== SS SS SS SS SS SS SS SS SS SS SS a Se SS SS SS SS eS SS SS Se ee ee 


Figure 3-2 Rezero Unit command descriptor 
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REQUEST SENSE (03) 
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This command returns Sense information for the addressed logical unit 
(LUN). The Sense data, which is reserved for the host, is valid for the 
most recent Check Condition (Completion Status) presented to the host. 
(Refer to the “Completion Status” and “SCSI Messages” sections.) 
However, Sense data is cleared when the faulty unit receives a subsequent 
command from the host that received the Check Condition. Figure 3-3 
shows the command descriptor. 


nan nda natpennatfoen beepers ener} ent parentprem penan aanefaeedpanadpeeeteanefoenderee}eranbranhounhoeefruntbaaetavedorentpematenetfaetandpamnferefemnbamnpasnfemnbametearfavefomrhondenndammbevenbaneafomadonael 
SE ee ee ee ee eS ES ES SS ES SS OS Se DE ED ES NE ET DN AOE ND SN SD RO 


| BIT | 

wee ew ewe ew ew we ww ow See ee meee me we ae eee a ee we ee ee ee ee we ee ee ewe we we ww we oe wn eee 

ne cae ee = ae) Cen ca ea eS oS Ee © 
BYTE  ==S=S=SSSSsSSS22rssrsssrses SST STs TS SSS SSS TT TST 
OO Oe he Oe Ps 908 EQ Ne Oe Bo Pd the ge Al 
01 | LUN | Reserved 
o2 | Reserved | 
os | Reserved | 
04 | Allocation Length | 
05 | Reserved | 


Fee dernentpeene fener ennd oereoeendperenpoemapenratperanfonenferntenveeh rene} enn pened preedpeatoeem peracid rvertpaers pee pene bree oaneareduaradpenetpueahreteeetpemcberenpeeed rebeatoandeententeaatempusntemapaatoned 
ee re ee ee Se ae ee ee ee ee a Ee AE SS 


Figure 3-3. Request Sense command descriptor 


Byte 04 (Allocation Length) of the Command descriptor specifies the 
number of bytes that the host allocates for returned Sense data. The 
controller may not return more bytes of Sense information than the 
number of bytes the host allocated. If descriptor byte 04 is less than four, 
the controller returns a default value of four bytes. (Refer to the “Sense 
Information” section.) 
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FORMAT UNIT (04) 


This command causes the controller to format and certify the specified 
logical unit. The entire disk is formatted except for the controller 
cylinder. The controller cylinder is cylinder zero for all heads and it 
contains controller information like Mode Sense, Defect List, scratch area, 
and soon. The controller cylinder is only formatted under the following 
conditions: (A) when the first format is performed on an unformatted 
drive or (B) when the bytes per sector has changed through a drive-strap 
change in the hard-sector mode or a Mode Select command in the 
soft-sector mode followed by a Format command. Once the format is 
complete, the controller digitally certifies all tracks not in the defect list. 
The controller assigns alternate sectors or tracks to user and maintenance 
tracks which do not pass certification or are in the defect list. Figure 3-4 
shows the command descriptor. 


erect ene feeeatenathometepencbecadheerhorademPperrdenchenetnanheerberedeenderehenferedbeeednatheerdeehuntmanhemntoendamnberadpetoratoanhers}ambmanteaatucndeantantemntorneuntoan’ 
ee ee a a a nn ee re ee ee ee a ae en ee Se ee ee 


| BIT | 

Lee M.D ie eB ack aS ee Sy Be A a ale el 
BYTE SS SSSSSsSSSSssrsessS Sessa SSS SSS SSS SSS SSS SSS 
00 O> 40 Ged Oe oe ae Oe Ve “sl 
01 | LUN IFmt |Compl! List Format | 

| IData IList | | 
o2 | Reserved | 
os | MSB Interleave | 
04 | LSB Interleave | 
05 | Reserved | 


ee ee es ee ee es er re ce ee ee ce ee ee ee te ne a a oD SR De a SE SS a A AS SS es SO eS SOD ERD eT SUES eS 
Se Se ee ee eS EE SE ET TL 


Figure 3-4 Format Fixed Unit command descriptor 


All defective sectors and tracks found during certification are added 
to the Growth Defect List (G List). After successfully completing the 
Format Unit function, the controller writes and maintains the Defect List 
on the controller cylinder of the disk drive. After termination of the 
Format Unit command, the controller formulates and returns to the host a 
Completion Status byte followed by a Command Complete message. 
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SCSI CCS COMMANDS 


The cylinders on the formatted drive are utilized in the following 
manner. 


Physicai Logical 

Cylinder Number Cylinder Number Utilization 

0 - Mode Select parameter 
save area, alternate 
track table 

1 - Maintenance Cylinder 

2—M O—N User Space including 


alternate tracks 


The user will always use the logical cylinder number (except for 
certain diagnostic commands) and will never be aware of the other two 
cylinders. 


Bytes 03 and 04 of the Format command descriptor specify the lacing 
factor or interleave to be used when formatting. Interleaves are indicated 
as follows: 


Interleave of zero 
An interleave of zero or greater than the number of sectors on a track 
indicates the controller uses the default interleave of one when 
formatting. 

Interleave of one 
An interleave of one indicates that consecutive logical blocks are also 
consecutive physical blocks. 

Interleave of two 
An interleave of two indicates that consecutive logical blocks are 
placed at every other consecutive physical block. 

Interleave of three 
An interleave of three indicates that consecutive logical blocks are 
placed at every third consecutive physical block. This formatting 
pattern continues in numerical order. 


Byte 01, bits 0, 1, 2, 3, and 4 of the Format Unit command descriptor 
provide the controller with the following Defect List information: 


LIST TYPE LIST FORMAT 
Bit: 4 3 2 1 
x No List 0 x xX Block Format 
1 0 Partial List 1 0 0 Bytes From Index 
Format 
1 1 Complete List 1 0 1 Physical Sector 
Format 
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The controller handles the alternate-storage assignment for the 
defective areas. Since this is done independently of the host system, a Unit 
Defect Table and information specifying the alternate sectors and tracks — 
assigned to the alternates are stored on a dedicated, non-user area of each 
disk drive. By using the dedicated disk space, a permanent record of the 
Unit Defect Table and the remaining alternate-storage space is 
maintained for controller use. The controller is directly responsible for the 
integrity and contents of dedicated disk areas. 


No Defect List (No List) 
If the controller receives a Format Unit command without a Defect 
List (No Format Data, or Length of Defect List = 00 and no Complete 
List bit) the controller receives defect information from the existing 
Unit Defect Table which is maintained on each unit by the controller. 
The controller formats and verifies as good, any blocks which are not 
specified in the Unit Defect Table. 

Incomplete Defect List (Partial List) 
If the controller receives a Format Unit command with a partial 
Defect List, the controller adds these values to those maintained in the 
existing Unit Defect Table. The controller uses this resultant Unit 
Defect Table to format the media. A partial list will contain logical 
blocks only. 

Complete Defect List (Complete List) 

_If the controller receives a Format Unit command with a complete. 

Defect List, the controller formats any block not specified in this 
complete Defect List as good and verifies the format. 


The controller marks any. sector which cannot be verified after 
formatting as defective and assigns an alternate-sector. If the controller 
assigns an alternate-track, the controller adds to the Unit Defect Table 
the logical cylinder, head, and sector-address of the defective sector. 


In any of the three above cases - No Defect List, Incomplete Defect 
List, or Complete Defect List - the controller uses a resultant defect list to 
format the disk. All tracks containing more defective blocks, which are 
specified in this list, than alternate-sectors on the track is automatically 
formatted as defective, and the controller assigns an alternate-track. 
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The following table explains the bit settings of the format data the 
controller receives from the host. 


A cee ee ce Se ee aR HD STON SE tS SY SE SA SE SD ED SS ES SS OE SD SE AD SE SSD A RD SE ED SON SS A SS SED ED STREETS TE SU ED CED nD wD 
ee ae ee re ae ae Ne ee SD DE SE SS le a A AS SD AEE Re AS SUE: 


| BIT | 

Fahy eae Ue - Sm ~ Sa a a «| 
BYTE  =SsSs=SSsSS=SSSSS2SSSSSSSSSSSSSSSSSSSSSSSSSS==S=SSSS== 
oo | Reserved | 
01 | Fov IDPRY IDCRT ISTPF | Reserved | vu 
o2 | Defect List Length (MSB) | 
oh Defect List Length (LSB) | 


ee ee ee re ce a eee re a ree a te ere ree re ees ee ee Se ts te core oe onee Se a eee SS Sore eee TED eS SE ED em wom Sua Se 
ee ae ae ae eS ee ee ee ee SS ES SE SS SS SS LS a A A SP SS AT A AS A SAE 


Byte 01, bits 4, 5, 6, and 7 of the Defect List Header provides optional 
format control. These bits define how the host optionally controls the 
Primary Defect List and the Target Certification flaw management 
schemes during the Format Unit command. The bits are defined as 
follows: 


Bit 0: Vendor-Unique (VU) 

Bit 1: Reserved 
Bit 2: Reserved 
Bit 3: Reserved 
Bit 4: Analyzed by the controller 
Bit 5: Analyzed by the controller 
Bit 6: Analyzed by the controller 
Bit 7: Analyzed by the controller 


Format Options Valid (FOV) Bit 7 


FOV bit 7=0 
Indicates that the host requests implementation of the controller’s 
format-default scheme for the functions defined by bits 4, 5, and 6. 
When bit 7 is set to zero, the host sets bits 4, 5, and 6 to zero; 
otherwise, the controller creates the Check Condition status with 
Illegal Request Sense key. 

FOV bit 7=1 
Authorizes setting bits 4, 5, and 6. If the controller does not support 
the functions defined by bits 4, 5, and 6 set to one, the controller then 
creates the Check Condition status with Illegal Request Sense key. 
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Disable Primary (DPRY) Bit 6 


DPRY bit 6 =0 

FOV bit 7=1 
Indicates that the controller manages the Primary (P) List of defects 
during formatting. When the controller fails to find the P List or does 
not know if it exists, the controller creates the Check Condition status. 

DPRY bit 6=1 

FOV bit 7=1 
Indicates that the controller excludes the P List from the list of flaws 
to manage during formatting. 


Disable Certification (DCRT) Bit 5 


DCRT bit 5 =0 

FOV bit 7=1 
Indicates that the controller enables the controller certification routine 
during formatting. 

DCRT bit 5=1 

FOV bit 7=1 
Indicates that the controller disables the controller certification 
routine during formatting. 


Stop Format (STPF) Bit 4 


STPF bit 4=0 

FOV bit 7=1 
Indicates that the controller continues the format process when the P 
or Growth (G) Lists are not accessed successfully in whole or in part. 
The controller creates a Check Condition status when the format 
process with the Recovered Error Sense key is completed, if no errors 
occurred other than failure to successfully access the P or G Lists. 

STPF bit 4=1 

FOV bit 7=1 
Indicates that the controller stops the format process upon failure to 
access successfully, in whole or in part, any of the P or G Lists. The 
controller creates the Check Condition status with Medium Error 
Sense key. 
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REASSIGN BLOCKS (07) 


This command passes the Defect List of logical blocks to the controller. 
The controller assigns an alternate-storage space to logical blocks 
specified in the Defect List. Data on the blocks in the Defect List is 
destroyed. Data on blocks that are not in the Defect List is preserved. 
Figure 3-5 shows the Reassign Blocks command descriptor. 


oe ere ee ES SS ES A SS SE nN MN ED SY SE EE AR OD OE ST SS SED SD AP EN SED SED SNAP STS SD SAS SS GNI SD SD SAEED GED AND SHES 
Oe a ee ne es ee Ee ET SE A SS ee a Me SSS AR ee Ste ERA ete oem 


| BIT | 

1? bets |4tisitetaiiel 
BYTE ===s=ssssssssssssssssssSsssssaassssssSsssssSSsS= 
CON ay 2a a tO He ae OU eee al. Oe he en che a as 
0. lun | Reserved | 
eh Reserved | | 
Go. ee Reserved = | 
ge Reserved | 
Ge ee es Reserved | | 


epee neneence endeared tpeeentprwethomn ores perereharedereetemnbemndpemrehenatenafamepenntensdarnpemafeun-banafewntansteandarechenaspembumperfecsdaseapem}emteenbrachredornderedendenatrantaned 
Se ee ae Se ee Se Ee Se Se ES EE TT Se SL A SL eh AD Se ES 


Figure 3-5 Reassign Blocks command descriptor 


Figure 3-6 shows the Defect List format. . 


DEFECT LIST FORMAT 


Byte Offset Length Definition 

00 2 Reserved. Must be zero. 

02 2 Length of Defect List in bytes. 
Must be less than 5632. 

04 » 4 Defect list. A logical block 


address is four bytes long. 


Figure 3-6 Defect List format 
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READ DATA (08) 

. This command transfers a specified number of blocks to the host, starting 
at the specified logical starting block address given in the command 
descriptor Logical Block Address field. To perform this command, the 
selected disk drive moves the heads to the track containing the block or 
sector addressed by the command descriptor. Figure 3-7 shows the 
command descriptor. 


a ce an ee we cee ce a Se cee ce a ree ee re ee ee ee wee re cn ce ca ete re ce re ee rr ce ee et a cre a ee es ee ae te ee 
a ee ae re ae re ee ee ee a ae ee ae a eS eS EE SE A LS a 


| BIT | 

i ie ee ae ee ee ae ee 
BYTE Sse 2seeSs= eos Sree Ss 
00 Oe. sO? Ser a sae 7 eek Ik Ge Sn 4 
01 | LUN | Logical Block Address (MSB) | 
oe Logical Block Address | 
o |: Logical Block Address (LSB) | 
a i i Transfer Length —=*&!: 
ee: ee ee deserved 8 oe 


oe re es ee a a coe ee ae eS A ae eS ee Sa SO ed SD Ne a ee ee A SS A SS Sa ee Dae 
a en a re a a ee ae a a ee ee a SE ES 


Figure 3-7 Read Data command descriptor 


The controller transfers two bytes of SLI (Sector Length Indicator 

_ which is prefixed to each block of data) and 256, 512 or 1024 bytes of data 
from the drive into the controller’s sector buffer. Next, the controller 
removes the SLI bytes from the data block. Then the controller transfers 
the 256, 512 or 1024 bytes of data to the host. Logically consecutive sectors 
or blocks are read, and seeks are performed as necessary to transfer the 
number of blocks specified in the Number of Blocks field (transfer length) 
of the command descriptor. The controller automatically handles alternate 
tracks and sectors. In case of read errors, the controller automatically 
handles retries. The controller corrects correctable-bit-errors using Error 
Correction Code (ECC). 
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WRITE DATA (0A) 
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This command transfers to the controller the specified number of blocks 
starting at the specified logical-starting-block address given in the 
command descriptor Logical Block Address field. To perform this 
command, the selected disk drive moves the heads to the track containing 
the block or sector addressed by the command descriptor. Figure 3-8 
shows the command descriptor. 


| BIT | 

or te ceed ae ee Mag ae ord 
BYTE ==s=Ssssssssssss2ssssasssssssssaassssssssssssssss 5 
OO” 1h. 05 1 S05 hiogee hh as ote eS UT 20. (bes ee Oo 
01 | LUN. ___| Logical Block Address (MSB) | 
2:f ©. Logical Block Address —s! 
a eae Logical Block Address (LSB) | 
af ©. Transfer Length —=*SI:’ 
Os ee ee Reserved °° J 


ee te er re a a ee oe ee we ee ne ee ee re re ee rn a a a a 
SSS SS SS SS SS SS SS SS SS SS SS SS SS SS eee ee ee ee 


Figure 3-8 Write Data command descriptor 


_The controller transfers data from the host to the controller’s sector 
data buffer. Next, the controller prefixes two bytes of SLI (Sector Length 
Indicator) onto the 256, 512 or 1024 byte data block. The two SLI bytes 
contain the length of the sector (256, 512 or 1024). The controller transfers 
258, 514 or 1026 bytes (2 SLI bytes and 256, 512 or 1024 data bytes) to the 
drive to be written. (Sectors of 1024 bytes are only available on external 
buffer controllers.) 


Logically consecutive sectors or blocks are written, and seeks are 
performed as necessary to transfer the number of blocks specified in the 
Number of Blocks field (transfer length) of the Command Descriptor. The 
controller handles alternate sectors and tracks automatically. 


SEEK (OB) 
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This command causes the controller to move the heads of the selected 
drive to the cylinder indicated by the command descriptor Block Address. 
Figure 3-9 shows the command descriptor. 


ee me a a re ee a a mw rr re we re a re es ce re re a a a a a we re a re es ee ee an ee ee ee 
Se ae ae se ae ee ee ee SS eS SS Se ee ee ee ee ee a ee Se SS a ee a eee 


| BIT | 

ar oe ee ee ed ae ee ee 
BYTE =S=sSsss=sssssssssssssssssssssssssssssssSsas===S= 
O00 4 7: 1 28> ee OE eg? Te ae hogs dh aie ae de 4 
01 | LUN | Logical Block Address (MSB) | 
erie eg Logical Block Address | 
ol ©. Logical Block Address (LSB) | 
oe OS Roceceaa, 
OS Me Reserved | (| 


Shaner re Peenahearedeanedenenbeendeeeerendenerbanedeeehemedemberend reenter ennterendeanderrademnteranbeeemperediemehareapemepareebeentarenberrdoemc eer fonedeapaeeteardranhereteambanetoudeuntaandpssiat 
Se SS SS SS SS SS SS Se ae eee ee ee ee eee eS ee ee 


Figure 3-9 Seek command descriptor 
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INQUIRY (12) 


This command requests the controller to send to the host information 
regarding its parameters and the parameters of its associated peripheral 
devices. Figure 3-10 shows the command descriptor. 


| BIT | 

(eae ee ee ae ee ee ee 
BYTE ==s=s===sssssssssssssssssssssasssssssssssss=s=s== 
00 Os GE gr he ag) ee ae oO, gee etcde uke ae od 
o1. |LUN | Reserved | 
og | Reserved | | Desired Data Format | 
Og. es Reserved | 
og Ge Allocation Length ——sS! 
oi ©. Reserved | 


Figure 3-10 Inquiry command descriptor 


The Allocation Length specifies the number of bytes that the host 
allocates for returned Inquiry data. An Allocation Length of zero 
indicates that no Inquiry data transfers. This condition is not an error. 
Any other value indicates the maximum number of bytes to transfer. The 
controller terminates the Data-In phase when either the allocation length 
bytes have been transferred or when all available Inquiry data has been 
transferred to the host (whichever is less). 


The Inquiry command returns a Check Condition status only when the 
controller cannot return the requested Inquiry data. 


If the host sends an Inquiry command with a pending unit attention 
condition (before the controller reports the Check Condition status), the 
controller performs the Inquiry command without clearing the unit 
attention condition. 


Inquiry Data Format 
The Desired Data Format field specifies the desired format for the 
Inquiry data. This field is analogous to the Response Data Format field in 
the Inquiry data. The following entries are accepted: 


e 0: Return data in the SCSI-1 Controller format (45 bytes of 
vendor-unique data) 
e 1: Return data in the CCS format (55 bytes of vendor-unique data) 


Figure 3-11 shows the Inquiry data format for command data. 


Offset 
Byte 


00 


01 


01 


02 
03 
03 


04 
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COMMAND DATA FORMAT 


Offset Byte 
Bit Length Description 


All 01 DEVICE TYPE: 


00 - Direct access magnetic disks 
7F - Device not present 
7 —_ REMOVABLE MEDIUM: 


O - Medium fixed 
1 - Medium removable 


6-0 — Device Type Qualifier (From Mode 
Select) 

All 01 Version: 00 

7-4 — Reserved: 0 

3-0 — RESPONSE DATA FORMAT: 


As requested in Inquiry command 


0 - SCSI-1 format 
1 - CCS format 


All 01 ADDITIONAL LENGTH: 


2D (45 bytes) - SCSI-1 format 
37 (55 bytes) - CCS format 


Figure 3-11 Command data format 
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Figure 3-12 shows the Inquiry data format for SCSI-1 Controller 
additional data. 


SCSIi-1 CONTROLLER ADDITIONAL DATA FORMAT 
Offset Offset Byte 


Byte Bit Length Description 
05 All 01 FEATURES SUPPORTED: 
(1 = supported) 
(O = reserved) 


Bit 7=1 — NCR commands w/SLI 
option 

Bit 6=1 — NCR commands w/ECC 
option 

Bits 5-1=0 — Reserved 

Bit O=1 — SCSI extended commands 


06 All 01 Controller firmware release level 
07 All 01 Controller firmware release level 
08 _ 04 “NCR” 
12 _ 16 Controller identification in 
ASCII 
28 —_ 16 Unit identification in ASCII 
(from Mode Select) 
44 _ 06 Controller firmware release level 
in ASCII 


Figure 3-12 SCSI-1 Controller additional data format 


Figure 3-13 shows the Inquiry data format for CCS additional data. 


CCS ADDITIONAL DATA FORMAT 
Offset Offset Byte 


Byte Bit Length Description 

05 _ 03 Reserved — 00 

08 _ 08 Vendor identification: “NCR” 

16 _ 16 Controller identification in ASCII 
32 _ 04 Hardware release level in ASCII 
36 _ 08 Firmware release level in ASCII 
44 _ 16 Unit identification in ASCII 


(from Mode Select) 


Figure 3-13 CCS additional data format 
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The controller Identification field that is returned as part of the 
Inquiry data field (Byte offset 12 — SCSI-1 data format or Byte Offset 16 
— CCS data format) will contain the following format for SDC 
controllers. All data is returned in ASCII. 


SDC CONTROLLER IDENTIFICATION 
Byte Offset Byte 


in field Length Description 
(0) 4 _SdCc 
4 2 SDC chip used 01-SDC1 
6 2 Hard disk interface 

01 — ST-506 

02 — ESDI 
8 2 '_ Buffer type 

01 — Internal Rotating 
10 2 Flex support 

00 — None 


01 — Single/Double density 
02 — High density 


12 . 4 To be determined 


Figure 3-14 SDC Controller identification 
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MODE SELECT (15) | 
i This command provides a means for the host to communicate with the 


controller to specify or change the medium, logical unit, or peripheral 
device parameters. Figure 3-15 shows the command descriptor. 


| BIT | 

17 !e@itsiaistgatitlo =| 
BYTE sSssssssssssssssassssseasssssssessssesssssssssss= 
00: «70. Wh sO Ay oe A ae eg aT i al 
01 |LUN | Reserved | | SP | 
a) a Reserved © ~—«*L: 
680 Resareea 
a4: ©. Parameter List Length _—s=i| 
A en OR Reserved ~«S| 


ee Oe YE NE SE SY SOY SE SD SE ND ST SS ed ND SR A SD SE SO SE SD SS AS SS ARS TE A OY Dn SD ED OT US SD MS GS RD mS 
ee re ee ee re ee ee ee ce ee a ee ee ete ce a ee ED ED DS ES SS SE A TT aS Me Am 


Figure 3-15 Mode Select command descriptor 


Save Mode Parameters (SP) Bit 
The SP bit 0, byte 01 set to one indicates the following: 


e The controller updates the current mode values with the values 
defined in the following Pages. (See NOTE.) 

e The controller saves all Savable Pages, except those defined by Page 
Code 03 which is to be saved during the next successfully completed 
Format Unit command. 

e After completing the above functions, the controller reports Command 
Complete with no Check Condition status. 


NOTE: Pages are blocks of parameters. Savable Pages are Pages the 
preceding Mode Sense command returns with the PS bit (bit 7, byte 0) 
of the Page Header set to one. 
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The SP bit 0, byte 01 set to zero indicates the following: 


e The controller updates current mode values with the values defined in 
the following Pages. 

© The controller does not save the Savable Pages. 

e The controller does not modify the saved parameters for Pages defined 
by Page Codes 03. 

e After successfully completing the above functions, the controller 
reports Command Complete with no Check Condition status. 


The Parameter List Length specifies the length (in bytes) of the Mode 
Select parameter list transferred during the Data-Out phase. A 
Parameter List Length of zero indicates no data transfers. This is not an 
error condition. 


Mode Select Parameter List 
The following Mode Select parameter list has a four-byte header followed 
by zero or more Pages. Figure 3-16 shows the Mode Select Parameter 


List. 
| MODE SELECT HEADER | 
| BIT : | 
as cae, AO - ce a = OO SS ee es © | 
BYTE ===s=SS=sS=Ss=SS>SSSSSSSSS SSS SSSSSSSSSSS SSS >> 
00 Reserved | 
O01 | Medium Type: 00 = Fixed disk | 
o2 | Reserved | 
03 | Reserved | 
| PAGE DESCRIPTOR(S) | 
| | | | - | | | | 
BYTE SSS SSS SS SSS SSS SS SSS SS SSS SSS SSS SSS SSS SSS SST STS TSS 
00 | Page Code | 
o1 | Page Length (in bytes) | 


ar cr a ce a ae a nr a ce rs es ree eee cree ae er ee ca a ce ee me er ae a re a rer ee a ae ee ree we ee re em oe 
ee ae ee ae Se a re ee Se ee ee ee ee ee ee ee ae a ee ee DT ee De ET A LT LT VL ce RE 


Figure 3-16 Mode Select parameter list 


In the Data-Out phase of the Mode Select command the host sends 
additional blocks of parameters called “Pages” to the controller. This 
occurs after the host sends the Mode Select Header. 


The Page Length indicates the number of bytes the controller supports 
for each Page. The Page Length value for each defined Page does not . 
include the Page Length byte. The Page Length, set in the Mode Select 
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command pages, is the same value (zero value included) that the controller 
returns in the Mode Sense Page Length bytes. Otherwise, the controller 
creates a Check Condition status with the Illegal Request Sense key. 


Before issuing a Mode Select command, the host may need to know 
which Page(s) the controller implemented and the length of each Page for 
a particular Logical Unit Number (LUN). The host obtains this data by 
issuing a Mode Sense command requesting the controller to return all 
Changeable values (refer to the PCF field configuration 01 in byte 02 of 
the Mode Sense command descriptor). The disk drive parameters are 
obtained from the ESDI drive interface. 
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Figure 3-17 provides the direct access device format parameters. 


DIRECT ACCESS DEVICE FORMAT PARAMETERS 
PAGE CODE 03 (HEX) 


Bytes. Function Change- Range Defauit 
(DEC) . able (Hex) (Hex) 
00 Page Code No 03 Required 
(No default) 
01 Page Length No 16 Required 
(No default) 
02-03 Tracks per No 0001 Required 
Zone (No default) 
04-05 Alternate . Yes 0000-Zero 0Q000-Zero 
Sectors or 
per Zon 0001-One 
06-07 Alternate No 0000 No support 
Tracks 
08-09 Alternate Yes Max/25% 82 
Tracks per of total 
Volume, with Mg tracks. 
1664 tracks Min/No. of 
maximum. tracks on 
Cylinder 1 
(Number 
rounded 
up to cyl. 
boundary) 
10-11 Physica Yes/No Variable 0022 (Note 2) 
Sectors (Note 2) 
per Track 
12-13 Data Bytes Yes/No 0100, 0200 
per Physical 0200, 
Sector . 0400 
14-15 Interleave No XXXX No support 
(Parameter 
passed in 
Format Unit 
command/value 
returned in 
Mode Sense 
commana) 


Figure 3-17 Direct access device format parameters (1 of 2) 
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DIRECT ACCESS DEVICE FORMAT PARAMETERS 
PAGE CODE 03 (HEX) 


Bytes Function Changeable Range Default 
(DEC) : (Hex) (Hex) 
16-17 Track Skew Yes 0 to 0000 
Factor PSPT-1 
(Note 1) 
18-19 Cylinder Skew Yes 0 to ; 0000 
Factor PSPT-1 
(Note 1) 
20 Drive Type No 80-Soft(2) No default 
Field 40-Hard 
CO-Both 
21-23 Reserved - NO 000000 Required 
(No default) 


(1) Physical Sectors Per Track = PSPT (Bytes 10-11) 

(2) For hard sector drives, the physical sectors per track and data bytes per physical sector are 
determined by the drive and can be obtained by doing a Mode Sense command for soft 
sector drives. The number of physical sectors per track that can be used for a particular 
number of data bytes per physical sector is a function of the total unformatted bytes per 
track, various parameters and the motor speed tolerance of the individual drive. Typically, 
there will be 62 256-byte-sectors or 34 512-byte-sectors or 19 1024-byte-sectors 
available. This can vary. 


Figure 3-17 Direct access device format parameters (2 of 2) 
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Figure 3-18 provides the vendor-unique fixed disk drive parameters. 


VENDOR-UNIQUE FIXED DISK DRIVE PARAMETERS 


PAGE CODE 20 (HEX) 


Bytes Function Change- Range Defauit 
(DEC) able (Hex) (Hex) 
00 Page Code No 20 Required 
(No default) 
01 Page Length No 14 Required 
(No default) 
02-17 Unit !D in Yes — (Blanks) 
ASCII 
(Returned 
by Inquiry) 
18 Device Type No _ 00 
19 Device Type Yes —_ 07 
Qualifier 
20 Rotational! Yes 00-No RPS 00 
Position 01 to 
Sensing (LSPT-1) 
(RPS) Offset 
Offset requested 
21 Disconnect Yes Bit O: 03 
Option Byte Disconnect 
after 
receiving 
command. 
Q=No 
1 = Yes 
Bit 1: 
Disconnect 
during seek. 
0 = No 
1 = Yes 
Other bits 
ignored. 


Figure 3-18 Vendor-unique fixed disk drive parameters 
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RESERVE (16) 


Extent Bit 
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This command reserves logical units, or extents within logical units, for 
the host. When using the Third-party Reservation option, the logical units 
or extents are reserved for another specified SCSI device. The Reserve 
and Release commands provide the basic mechanism for contention 
resolution in systems having multiple-hosts. Figure 3-19 shows the 
command descriptor. 


| BIT | 

| v7 | 6 I § | 4 4 3 «| @ | 1a too f 
BYTE = ====SS==S= SS S>S=SSSSSSSS=S SSS SSS SSS SSS SSS = SS= 
00 0 | oO | Oo ieee § | oO 2 | 2 | 0 | 
01 | LUN | 3rd |3rd Party Device /Ex- | 

| | pty | ID ltent | 
o2 | Reserved | 
os Reserved | 
04 | Reserved | 
05 | Reserved . | 


en te eee ae ee Ss A ee ED I cee eS ST SO ES SD SY RE SN SOE SO OS SD EE SD SS ED AS GS SD SE SED TD SD SD SED SS GE SD SED SS oe cs 
ae ee ee ae ca ae ee ee a ee a ae ee Se eS ES OE EE SE NS NS SS ES A A ST A SS AY SP AS Ae se 


Figure 3-19 Reserve command descriptor 


Extent bit = 0 
This command requests that the host receive exclusive use of the 
logical unit. This reservation is in effect until one of the following 
occurs: 
e Another valid Reserve command from the host originating the 
reservation supersedes it. 
e A Release command from the originating host releases it. 
e Any host issuing a Bus Device Reset message. 
e A hard Reset condition occurs. 
The system permits a host system to reserve a logical unit that is 
currently reserved by that same host. If the extent bit is zero, the 
Reservation Identification and the Extent List Length are ignored. 

If the logical unit, or any extent within the logical unit, is reserved 
for another host, the controller responds by returning a Reservation 
Conflict status. 

If another host honors the reservation, but later attempts to send 
commands to the reserved logical unit, the system rejects all 
commands having a Reservation Conflict status, except the Release 
command, which is ignored. 
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The Reservation Identification permits a host to identify each 
Extent Reservation. The Reservation Identification also permits a 
host, in a multiple tasking environment,.to have multiple reservations 
outstanding. In the Release command, the Reservation Identification 
specifies which reservation to release. If used in superseding Reserve 
commands, the Reservation Identification specifies which reservation 
to supersede. 

The Extent Reservation and the Extent Release options permit 
multiple extents within the logical unit selected for reservation, each 
with a separate reservation type. 


Extent bit = 1 
The controller processes the reservation request as follows: 


1. The controller checks for the number of extents in the reservation 
request. If the Extent List Length is zero, no reservations change. 
This condition is not an error. If the Extent List contains more extents 
than allowed on a logical unit, the command terminates with a Check 
Condition status and the sense key sets to Illegal Request. If the extent 
list contains more extents than are currently available on the logical 
unit, then the controller returns Reservation Conflict status. 

2. The controller checks for valid extent logical block addresses. If any 
logical block address is invalid for this logical unit, the command 
terminates with a Check Condition status and the sense key sets to 
Illegal Request. The controller checks for invalid extent overlaps . 
(defined by reservation type) with other extent descriptors in the 
Extent List. If invalid overlaps occur, the command terminates with a 
Check Condition status and the Sense key sets to Illegal Request. 

3. If no conflict occurs between the requested reservation and any active 
(or previously requested reservation), the specified extents remain 
reserved until one of the following occurs: 

e Another valid Reserve command from the host originating the 
reservation supersedes it. 
e A Release command from the originating host releases it. 
e Any host issues a Bus Device Reset message. 
e A hard Reset condition oecurs. 
When a Bus Device Reset or hard Reset occurs, the next command 
from each host system terminates with a Check Condition status and 
the sense key sets to Unit Attention. 


4. If the reservation request conflicts with an active reservation, the 
controller returns a Reservation Conflict status. 
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Figure 3-20 provides the data format of extent descriptors. 


ee ee tin te tee ee ae SS Se SH A ES SS SS WS aS DD ES SS TD SS a SD EY AEE ED Mh mn cS mh eS Se 
SS Oe ES SS EY ES SS SD AS SS NS AD ES AN NS IT A A LD SD SS A ES EE SS SS SS SS Te SD SS ED 


| BIT | 
[gy | 6 | § | 4 | 3 | 2 | | 0 | 
BYTE. =SsssSsSSSS2SSrSSSsSsrseesSsSsSsS SSS SSS SSS SSS SSS 
00 | Reserved [Reservation | 
| IType 
Ol | Number of Blocks (MSB) | 
02 | Number of Blocks | 
03 | Number of Blocks (LSB) | 
04 | Logical Block Address (MSB) | 
05 | Logical Block Address | 
06 | Logical Block Address | 
07 | Logical Block Address (LSB) | 


ae a ee ee a nS eS ED SAN SS RD OP SOLD SED AN GEE AD ND Se SE NT ST SE OS OD SE SY ED SY SA SAE AE NS GS AE SN SED US SS <O SD OD en 
ee ee re ee SE AS ee SS DE SE EE A A LS LE A a Se Se a eS A AS To SARS RS 


Figure 3-20 Data format of extent descriptors 


The Extent List Length parameter defines the size of the Extent List. 
This list consists of zero or more descriptors. Each extent descriptor 
defines an extent beginning at the specified Logical Block Address for the 
specified number of blocks. If the number of blocks is zero, the extent 
begins at the specified Logical Block Address and continues through the 
last Logical Block Address of the logical unit. 


The controller supports a maximum of eight extents, with a maximum 
of four extents per logical unit. 


The reservation-type field determines the reservation for an extent. 
Figure 3-21 shows the four types of reservations. 


DB (1) DB (0) Reservation Type 


0 (@) Read Shared (RS) 

e) 1 Write Exclusive (WX) 
1 @) Read Exciusive (RX) 

1 1 Exclusive Access (XA) 


Figure 3-21 Extent reservation types 
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Figure 3-22 shows the validity of reservation request and commands 
for host B when host A reserved an extent. 


ee re ee cee ee ce tes ee nee Se cee ee eS SE ce A SS a A ee eats me a ye 
So er ee Se Se Se ee a a ae ee ee ee ee ee ae ae ee eee ae ae ee eee eee eee 


|HOST B REQUEST: IHOST B REQUEST: | 
|EXTENT RESERVATION ICOMMAND TYPE 


HOST A SSS SSS SS SSS SSS SSS SS SS SSS SSS SS SSS SSS SS SS SSS SSS SST SST 
TYPE OF | RS OO | xX | Rc | RO!|RCO |X | RC | 
EXTENT «= =—«_ ds wwe w ww www ew wen cece cee wen ewes ewe nw ewes esewewensesens 
RESERVED | WX O21 | Ro | Re! x !re 1! X | RC | 
| RX 10 |} re |x | Re! Re /Re | xX | 
| AX 11 lpe dre ! re J-nc | Re | RC | 
X = No Conflict 
RC = Reservation Conflict 


re a ce re rs re a ee re es me re ee tn a a re rr ee rr te re a ee ee a ee ere ee ee ee ee ee we eee 
ee ee re ene a ne ee ee ae ee ee es ee Ee Ee cr A 


Figure 3-22 Reservation validity 


If a host attempts a command to a reserved logical block, the 
reservation prohibits access. The command terminates with a Reservation 
Conflict status. If a reservation conflict precludes any part of the 
command, none of the command is performed. 


The Third-party Reservation option for the Reserve command permits 
a host to reserve a logical unit or extents within a logical unit for another 
SCSI device. : 


If the 3rdPTY bit is zero, the Third-party Reservation option is not 
reserved. 


If the 8rdPTY bit is one, the Reserve command reserves the specified 
logical unit or extents for the SCSI device specified in the third-party 
device ID field. The controller holds the reservation until one of the 
following occurs: 


e Another valid Reserve command from the host originating the 
reservation supersedes it. 

e A Rélease command from the originating host releases it. 

e Any host issuing a Bus Device Reset message. 

e A hard Reset condition occurs. 
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3-28 


The controller ignores attempts to release a reservation made by any 
other host. 


A host with a current reservation may modify that reservation with 
another Reserve command to the same logical unit. If the new reservation 
request is granted, the new Reserve command releases the existing 
reservation. When the new reservation request is not granted, the existing 
reservation is not modified. If conflicts prohibit granting the new 
reservation (other than the reservation being superseded), the controller 
returns a Reservation Conflict status. 


SCSI CCS COMMANDOS 


RELEASE (17) 
This command releases previously-reserved logical units, or previously 
reserved extents within logical units. A host attempt to release an inactive 
reservation is not an error. When this occurs, the controller returns a 
Good status without altering any other reservation. Figure 3-23 shows the 
command descriptor for this command. 


crc ce rs es ce a ee re a a ce rr ee ee ee ere ee ce ae cs re cee a ee ee ee ee a a a ne se ae re ee ee ee ee re ee 
ee re Se Sa ae Se ce Oe ae a A ee ee ae ES A AE SE SS A 


| BIT 

| 7 6 | § | 4 | 3 | 2 | 1 | 0) | 
BYTE 2===s2=s===ss=22SSs22SS=S222sSsS2rsresSsssssssss=S=== 
00 | (@) | oO 1 Oo | 1 | @) | ne | 1 | 1 | 
Ol | Logical Unit | Sra | Srd Party lEx- | 

| Number | pty | Device ID ltent | 
o2 =| Reservation Identification | 
ok Reserved | 
04 =| Reserved | 
05. | Reserved a | 


a re ee ee a ne ae ee es ee ee Se ED eS a I a AD SE aS OT eS AD ES SE TS eS SS GP EY nS OY oes ee ee Se re 
Ee SE SS ET A A ee A 


Figure 3-23 Release command descriptor 


Extent Bit | . 
If the extent bit is zero, the controller terminates all logical unit and 
extent reservations that are active from the host to the specified logical 
unit. 


If the extent bit is one, a host request for a reservation with a 
matching reservation identification is terminated. Other reservations from 
the requesting host remain in effect. 
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Third- -Party Release Option 
The Third-party Release option allows a host to release a logical unit or 
extents within a logical unit that were previously reserved through the 
Third-party Reservation option. 


Third-Party (3rdPTY) Bit 
If the 3rdPTY bit is zero, the Third-party Release option is not requested. 


If the 3rdPTY bit is one, the controller releases a specified logical unit 
or extents if the following are true: 


e The host requesting the release used the Third-party Reservation 
option to make the reservation. 

e@ The release is for the same SCSI device specified in the third-party 
device ID field. 
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MODE SENSE (1A) 


This command provides a means for the controller to report its medium, 
logical unit, or peripheral device parameters to the host. This command is 
a complementary command to the Mode Select command. Figure 3-24 
shows the command descriptor for this command. 


me cs cs rs a rs a re ee ee es me rs cae ts a ee ee ree a cor we ee a ee ee wre ee ne ee ee 
== SS SS SS SS SS SS SS SS SS SS SS SS SS SS a ee a SS eS eee 


| BIT | 

(gee 6 dea a ee Le ae es 
BYTE ==sSssssssssssssssssssssssssssSssSssassssssss=s== 
00 Oe) 0 a OE ae a a) ee OT ake eo 
o2 | PCF. | Page Code © | 
ee Reserved | 
“41 | Allocation Length | | 
gi Reserved 


ee re ee re re ee cae es es re ee ee se me re ee ee te ee a te Sr ae oe SS a oD ED DSO SED “STU ns AA HD eR MN ce PD 
ee ee ae a ee ae ee ee ne ee Se Se ee a 


Figure 3-24 Mode Sense command descriptor 


The Page Control Field (PCF) bits 6 and 7 of byte 02 define the type 
of Page Parameter values to return. 


e (00) Current 

e (01) Changeable 
@ (10) Default 

@ (11) Save 


The Page Code bits 5 through 0 of byte 2 indicates which Page(s) to 
return. 


The Allocation Length specifies the number of bytes that the host 
allocated for returned Mode Sense data. An Allocation Length of zero 
indicates that no Mode Sense data transfers. This condition is not an 
error. Any other value indicates the maximum number of bytes to 
transfer. 


The controller terminates the Data-In phase when the Allocation 
Length transfers, or when all available Mode Sense data transfers to the 
host, whichever is less. 


The Mode Sense data contains a four-byte header, followed by zero or 
more eight-byte block descriptors, followed by zero or more Pages. 
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The command descriptor PCF bits 6 and 7 of byte 02 report current 
values, changeable values, default values, and saved values. The 
information that follows describes these bits. . 


COMMAND DESCRIPTOR BYTE 02 
Bit 7 Bit 6 Description 


0 0 Report Current Values 


” \f the Page Code is 3F, all Pages that 
the controiler implements are returned 
to the host with fields and bits set 
to Current values. 


\f the Page Code is not 3F, the Page 
defined by the Page Code (if supported 
by the controiler) is returned to the 
host with fields and bits set to 
Current values. 


Current values are either: 


* As set in the last successfully 
completed Mode Seiect command 


* Are identical to the Saved values if 
a Mode Select command was not issued 
since the most recent power on 


* Are identical to the Default values _ 
if no Saved values are availabie 


Fields and bits not supported by the 
controller are set to zero. 


COMMAND DESCRIPTOR BYTE 02 
Bit 7 Bit 6 Description 


0 1 Report Changeable Values 


if the Page Code is 3F, ail Pages that 
the controller implements are returned 
to the host with fields and bits that 
the host is allowed to change, set 

to one. The host is not allowed 

to change fields and bits set to zero. 


If the Page Code is not 3F, the Page 
defined by the Page Code (if supported 
by the controller) is returned to the 
host with fields and bits that the host 
is allowed to change, set to one. The 
host is not allowed to change fields 
and bits set to zero. 
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COMMAND DESCRIPTOR BYTE 02 
Bit 7 Bit 6 Description 


1 0 Report Default Values 


If the Page Code is 3F, ail Pages that 
the controller implements are returned 
to the host with fields and bits set to 
the controller's or device's Default 
values. 


If the Page Code is not 3F, the Page 
defined by the Page Code (if supported 
by the controller) is returned to the 
host with fields and bits set to the 
controHer’s or device's Default values. 


Fields and bits not supported by the 
controller are set to zero 


COMMAND DESCRIPTOR BYTE 02 


Bit 7 Bit 6 Description 


1 1 Report Saved Values 


if the Page Code is 3F, all Pages that 
the controller implements are returned 
to the host with fields and bits set 

to Saved values. 


if the Page Code is not 3F, the Page 
defined by the Page Code (if supported 
by the controiler) is returned to the 
host with fields and bits set to the 
Saved vaiues. 


The Saved values are: 
* Values saved during the most recent 
successfully completed Format Unit 


or Mode Select commands. 


The mode of Saving is vendor-unique, 
and values may be recorded on disk. 


Fields and bits not supported by the 
controller are set to zero. 


Current values may be modified by successfully completed Mode 
Select commands. Saved values are updated only by successfully 
completed Format Unit commands. A Format Unit command completing 
with no Check Condition status indicate that the saved values were 
successfully saved. 


A host may request that the controller return a specific Page by 
selecting its code in byte 02 of the command descriptor. 
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When a host selects a particular Page code in byte 02 of the command 
descriptor, the controller returns that Page. 


The command descriptor Page Codes for bits 0-5 of byte 02 are 
described as follows: 


COMMAND DESCRIPTOR BYTE 02 


Page Code Description 

(Hex) 

03 Direct Access Device Format Parameters 
20 Vendor-Unique 

3F Return ail Pages to the host. 


(Refer to the PCF bit configuration.) 


Page Code is valid for Mode Sense 
commands only. 


Figure 3-25 Mode Sense page code descriptors (Bits 0-5) 


The controller returns the same Page Length value in each Page that 
it supports with the 3F Page Code, dependent on the value of each bit of 
the PCF field. 


Figure 3-26 shows the Mode Sense Header. | 


| BIT | 

De oR aI, BN ee A, oe AY oe OE ee Qe | 
BYTE = =SSS=sSSSSSSSSSSsSSSSSSSSSSSSSSSSSSSSSSSSS=SSS=S=== 
00 Sense Data Length | 
o1 | Medium Type | 
o2 =| Reserved 
os | Reserved | 


Figure 3-26 Mode Sense header 


The Sense Data Length byte specifies the length in bytes of the 
following Mode Sense data available for transfer during the Data-In 
phase. The Sense Data Length byte does not include itself. If the 
command descriptor Allocation Length is not large enough to transfer all 
the Sense Data Length, the Sense Data Length does not adjust to reflect 
the truncation. 
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Figure 3-27 shows the Mode Sense Page Descriptor. 


a a es se a ae ar rs as rs es re es a re me ee care ee ae re see ee re ae rr a re ee ne a ee ee 
ee a a ee a re es re a a a ee re a ee a ae ee, 


| _ BIT | 
I ee sere Be che ia Be cal! Be ihe “aes eh Bg. 
BYTE SSSSeSesssSeSsTe SSS SSS SSS SSS SSS SSS TSS TSS SSS SSS = 
00 | Ps | Page Code | 
01 | Page Length (in bytes) | 
O2-n | Refer to Page definition in Mode Select | 


Figure 3-27 Mode Sense page descriptor 


The Parameters Savable (PS) bit 7 of byte 00 of each Page Header set 
to one by the controller indicates that the controller saves the supported 
parameters. 


The PS bit set to zero indicates that the controller does not save the 
supported parameters. 


Bit 6 of byte 00 is reserved. 


The Page Code identifies the meaning of ‘the bytes in the Page. The 
Page Code is defined, reserved, or vendor-unique. The defined Page 
parameters are classified in priority to ease implementation by the 
controller. 


The Page Length indicates the number of bytes the controller supports 
in each Page. The Page Length value for defined Pages does not include 
the Page Length bytes. 


Before issuing any Mode Select commands, the host issues a Mode 
Sense command to find out which Pages the controller implemented and 
the length of the Pages for the specific LUN. The controller returns all 
Changeable values (PCF field configuration 01 and Page Code 3F in byte 
02 of the Mode Sense command descriptor). 
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A Mode Sense command issued after a power on or reset results in one 
of the following conditions: 


Mode Sense Request: Controller Response: 


Default values Reports Defauit values 


Saved values Reports existing valid restore 
of parameters, or returns a 
Check Condition status. The 
Sense key sets to Illegal 
Request if the requested Pages 
are not saved. 


Current values ; Reports a valid set of saved 
parameters (if available) or 
the default parameters. 
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RECEIVE DIAGNOSTIC RESULTS (1C) 


This command requests that analysis data be sent to the host following 
completion of a Send Diagnostic command. Figure 3-28 shows the 
command descriptor for this command. 


cee re ae we re cee re a ar ee se ee we oe nr re ee re er ee ee re rr oe ee ee ee re ee oe 
a ae ee ee ae a ae a ee ee ae a ae a a ee ee SS SS ST LS TS LS LD ND NS Se SAA SY SAE A 


| BIT | 

(a ae ae ae ae ee ee a | 
BYTE sSssssssssssnsssssssssstassssssssssssssssssssSss= 
OO. 3) <0) ir on aes a cae a 2. <1 362. <I 
ox Viton ke epeewea 
nt i Receeved) =. 
ew ee ny Allocation Length (MSB) | 
Gee es Allocation Length (LSB) | 
of Heasrved = = —~«*L: 


re re ee rr rs coe es ee ee tee ee ee ee ee ee ares ne SS SS ED ee ED ce SS aD OD es <A SOD a ND aD Sn SE eS OND mY OU 
ee ee ee ee re ee ee eS eS SE A ST SS SSO NE 


Figure 3-28 Receive Diagnostic Results command descriptor 


The allocation length specifies the number of bytes that the host 
allocates for returned diagnostic data. An allocation length of zero 
indicates that no diagnostic data transfers. Any other value indicates the 
maximum number of bytes allowed to transfer. The controller terminates 
the Data-In phase when allocation length bytes transferred or when all 
available diagnostic data transferred to the host, whichever is less. 
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Receive Diagnostic File 
. Diagnostic Result File. Figure 3-29 shows this file. 


Byte: 00 | Flag * | 


Ol | Reserved | 
o2 =| MSB DATA Length | 
‘i | LSB DATA Length | 
| | | 
| | | 
: | Data Field | 
| | | 
No -seeecccccussce uw dee les 
a | Sense Length | 
| | | 
| : Sense Field ** | 
Mo ‘iseseseoscsiteoscuueaesoct 


* Flag: O = Valid Data/1l = Invalid Data 
(Test Buffer Command Only*) 


** Sense Field Format: Same as Extended Sense Format 
Figure 3-29 Receive Diagnostic File Format 


A Check Condition status is not returned when sense information is in 
the sense field. 
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SEND DIAGNOSTIC (1D) 


This command requests that the controller perform diagnostic tests on 
itself, on the attached peripheral devices, or on both. A Receive Diagnostic 
Results command follows this command, except when the self test 
(SelfTest) bit is one. Figure 3-30 shows the command descriptor. 


a a a a a i a i a i se se ee sr a a ee oe ee re ee ee ee oe ee ee ee ee ee 
ee ee cern cae ae ae ae we ae re ae re ee ee a ee ae ee ee ee eS ee ALL 


| BIT | 

nie I ves I ee sae. We ee ee ae ee iY Ses 
BYTE =sSSsS SSS SrSSSSSSserSsr sae ess SSS TTT SS= 
O60. sO0 I Oke 4s eS tis a es Se as oP gor oh fa 
01 | LUN | Reserved |Self | Reserved | 

| | ITest | | 
o2 si Reservation Identification | 
03s Diagnostic File Length (MSB) | 
04 «| Diagnostic File Length (LSB) | 
05 =| Reserved | 


a ee ae re re ee ca ee cr aS ee ED SS SS A SS A DS SO a Se SS A A SE SR GE ES SS SA es Ss 
care ee a ee ae ee Se ee EE ES Ee eT a A a A 


Figure 3-30 Send Diagnostic command descriptor 


The Diagnostic File Length specifies in bytes the length of the 
diagnostic file transferred during the Data-Out phase. A Diagnostic File 
Length of zero indicates that no data transfers. This condition is not an 
error. The parameter list is vendor-unique. 
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Self Test Bit 


A self test bit of one directs the controller to complete its default self test. . 
If the self test is requested, the Parameter List Length is set to zero and. 
no data transfers. When the self test passes successfully, the command 
terminates with a Good status. Otherwise, the command terminates with a 
Check Condition status and the Sense key sets to Hardware Error. 


A self test bit of zero directs the controller to get the actual function 
’ performed from the Send Diagnostic File Format, byte 03. eae 3-31 
shows this file format. 


beans ame dpemenparenpure=pumepoeredfan vader dpummpuorademantpereatpaentperenhparahuunadamndoatenmtaredaurdascabenahuretemmtemntummevstrenatannd 
a ee ee ee ee eee I ED SE ED SE SE SS SS NS ES Se SS Se aS Se ee Se Se Se 


Byte: 00 | MSB File Length | 
01 | LSB File Length | 
02 | Reserved (Must be zero) | 
03 | Function Code | 
04 | MSB Physical Block Address * | 
o | Physical Block Address: | 
o || Physical Block Address | 
07 | LSB Physical Block Address * | 
08 | MSB Number of Blocks ** | 
09 | LSB Number of Blocks ** | 
fe pene ee ea cose y 
| | | 
| | Data Field : 
| | | 
W’. “seecetaccos eo slacesee osc eaaae sess 


* Treated as Logical Block Address for 
Address Convert command. ‘ 


** Number of bytes for test buffer 
diagnostic function. 


Figure 3-31 Send Diagnostic File Format 


3-40 


SCS! CCS COMMANDS 


READ CAPACITY (25) 


This command provides a means for the host to request information 
regarding the logical unit capacity. Figure 3-32 shows the command 


descriptor. 

hoe eee BIT J 

fei. 6c L-~s toe ech eb he | 
BYTE ==S=ssssssssssssssssssasssssssssssssssssssssss=== 
OO." HE <0 i Os os a le Os ae a a 9? ae 
ol |LUN | Reserved | 
ae ee ey Logical Block Address (MSB) | 
Oe aes ee Logical Block Address sid 
ja ee Logical Block Address | 
ot ©. Logical Block Address (LSB) | 
fe Sesecvaae 
o” Il Reserved =u, OO 
a ea Reserved =. eM | 
o | © | Reserved. 


Figure 3-32 Read Capacity command descriptor 


Partial Medium Indicator (PMI) Bit 
A PMI bit of zero indicates that the information returned in the Read 
Capacity data is the logical block address and block length (in bytes) of 
the last logical block of the logical unit. The logical block address in the 
command descriptor block is set to zero for this option. 


A PMI bit of one indicates that the information returned is the logical 
block address and block length (in bytes) of the last logical block address _ 
encountered after a substantial delay in data transfer. This logical block 
address is greater than or equal to the logical block address specified in 
the command descriptor block. 


3-47 


SCSI CCS COMMANDS 


Figure 3-33 shows the eight-bytes of Read Capacity data sent during 
the Data-In phase of the command. 


| DESCRIPTION | 
BYTE =Sssssssss2sssstsssassmssssssseesessssssssSass=s= 
00 Logical Block Address (MSB) | 
on ee Logical Blook Address ——S—S~=S™ 
a2! © Logical Block Address —=d 
oy Logical Block Address (LSB) | 
Oe ete Block Length (MSB) = s—t—~*«S*S: 
oi Blook Length | 
oe | © Block Length = = =——té<i‘SCS 
Gh er eee Block Length (LSB)  ——'| 


ee ee ce ee eee ee te re te ca ee cre a cr a es as ee wes ne te ete ee es ee cee ren ee es ee ee ee ee ae aie es 
re ce ee a ee ee a a ee ee ee ee we ee ne eS ES SS SS AS SS NE OT AS eS 


Figure 3-33 Read Capacity data-bytes/data-in phase 
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READ EXTENDED (28) 


This command transfers a specified number of blocks to the host system, 
starting at the specified logical-starting-block-address given in the 
command descriptor Logieal Block Address field. To perform this 
command, the selected disk drive moves the heads to the track containing 
the block or sector addressed by the command descriptor. Figure 3-34 
shows the command descriptor. 


Oe ee ae a cree a ee A a A ED SS ee A SE eS a DD AD A A A SO eS SD Se ED ee 
ee ee ee Se en ae ee a ee a ee ee ae a eS ES SS SM SE ST aS OD SEND SS 


| BIT | 

ae ee ee ae ce a ee 
BYTE sisssmssasssssossssassessassssssssassSsssassss== 
OO: Te 56. 3b ao eh te Pe Ih aS Te gy A es =| 
o.- 1LUN I|fReservea = 1 
gg.t)7 ae Logical Block Address (MSB) | 
Ga. le lp Logical Block Address —_| 
a Logieal Block Address —_| 
Oe he eee Logical Block Address (LSB) | 
o | ©. Reserved tsti(‘i‘is~*™ 
eu ee ee Transfer Length (MSB) | 
ol ©. Transfer Length (LSB) ‘| 
bee Reserved ————SL 


ee te a res ee te ae cae ee ee in ce cee ce es me care ee ee Se NO SE DS A A A SD ES TS SS SE DE So SO ei Dn 
Se ee SE SS OS A ADS eS EE SS A ED NS ES EE TE SS OS ST a RED 


Figure 3-34 Read Extended command descriptor 


3-43 


- $CSI CCS COMMANDS 


WRITE EXTENDED (2A) 


This command transfers a specified number of blocks to the controller, 
starting at the specified logical starting block address given in the 
command descriptor Logical Block Address field. To perform this 
command, the selected disk drive moves the heads to the track containing 
the block or sector addressed by the command descriptor. Figure 3-35 
shows the command descriptor. 


| BIT | 

ig |e. | ee te. oe a Od 
BYTE =s=s=s=sssssssssssssssssssssssssssssssssssssssss= 
oo | o | o-!} 2 |oo dra | o F rt too | 
0. |lw:  |Reservea | 
peg Se ee Logical Block Address (MSB) | 
o +t © Logical Block Address ——si|! 
ja ee Logical Block Address —_! 
otf Logical Block Address (LSB) | 
61 4. Reserved | 
7 Transfer Length (MSB) | 
<a aaa SE Transfer Length (LSB) ——‘| 
Oe ett ee Reserved  . | 


Figure 3-35 Write Extended command descriptor 
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SEEK EXTENDED (2B) 


This command causes the controller to move the heads of the selected 
drive to the cylinder indicated by the command descriptor Block Address. 
Figure 3-36 shows the command descriptor. 


ce a a i tr a a as a re a tr ee a ee es es ce se ne a no ee 
oe a ee re ee a ee a a a re ee a a ne a ce ee ee re ee ee ee ae re ee ee ee ee et oe ee ee ee 


| BIT | 

ee oe oe i ee ee Pe to 
BYTE ==sSsssssssssssssssssassssssssssssssssassassaaa== 
OO" l- 20" ol! nc. I: ae. i ge ole” Tae oth. 2) al MP 2 ale“ aie 7 
ol. tu CSS: Reseceeg OCC 
etl | Logical Block Address (MSB) | 
os. ee Logical Block Address | 
a1 | Logical Block Address: | 
Os. ee Logical Block Address (LSB) | 
i ane Reserved = —t—<Csti‘CS OL 
bie de ee Reserved = stst=“‘SSSS 
ef... es Reserved st—<‘i‘C™SCSdL 
o | Reserved | 


Caper paenpnaenbreventpeendnnadpeneefonnsheanterenfunatpenrefernteaatemtteenteeaatere-fexnteamebernatemmtere team dpematpensteancteeassdenanpranfeaaabemeteeanburenborsedamntpomnatoent one}emntrsestaaetapaatomntanefamtimne puma 
ee ee A ee ee eS SE A ET ee EE SS TF 


Figure 3-36 Seek Extended command descriptor 
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WRITE AND VERIFY (2E) 


This command transfers a specified number of blocks to the controller, 
starting at the specified logical starting block address in the command 
descriptor Logical Block Address field. The command moves the heads of 
the selected disk drive to the track with the block or sector addressed by 
the command descriptor. 


After completion of the Write Data operation, the system verifies that 
the written blocks are read without errors. If data errors occur, the 
command terminates with a Check Condition status. Figure 3-37 shows 
the command descriptor. 


ee ee SE I A SD AA ES DS SD SD ED A SN A DS SR DNS MS A mY SE mS ES EY SD SD SE ND SO Sn YY cD SD 
ee ee ae ES ED A AS SE ee A ES LS Se VT 


| BIT | 

Toye eee ee ae ee ee 
BYU 8 222353223525 552>5 2-5 - eee ae Se 
00 Pe Se © tau am Qc Us es Sm Ry SS 
OF ton» Reserved tC 
ce a Logical Block Address (MSB) | 
si... Logical Block Address == 
ee Logical Block Address S| 
on Logical Block Address (LSB) | 
ol ©. Reserved ——“‘;O;CO!O#O#;~é*d 
aio 8 Transfer Length (MSB) | 
Gee ee ee Transfer Length (LSB) 
oc es i ee a Pedeeve, ce eee 


cna ene Free mend peed ewe prem reed eect eeneebpeenboetoeeroermprenderateretpenabereh an femeh rachennteendsadparabeecbeandperedpeeeteeerdeaeYuredreerdurelpemt ean }oned-anrdanetprardeeatpowuiemataerduaretparetount 
Fe a ae a ee ne a eS SE NE OE DD AD DS SS A A AE Ae ee a a TS SD eS ee 


Figure 3-37 Write and Verify command descriptor 
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VERIFY (2F) 


- This command requests the controller to verify the data written on the 
medium. 


After completion of the Write Data operation, the system verifies that 
the written blocks are read without errors. If data errors occur, the 
command terminates with a Check Condition status. Figure 3-38 shows 
the command descriptor. 


ee cee re ce me ee es pe cs ee ce ae a SS eS a SN ES SU Se A Se ND ee ee RD eS Ye 
en ee ee ee a a nn a ee a ee en re a re ee re ee ee 


| BIT | 

eo ee Na Wom roe Se ae AC Gy 
BYTE ====s==sssssssssssasssssssassSSsasSesssssssSsSSS= 
OO. 60) FOr UL i oe ae lle a ae ad Se 
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Figure 3-38 Verify command descriptor 
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READ DEFECT DATA (37) 


This command causes the controller to return the medium defect data oO; 
the host. Figure 3-39 shows the command descriptor. 


| BIT | 
Voge le Aes, tf aes he ie eo | 
BYTE =Sssssssssssssssssssssss2sessssssssssasss=ss2=2== 
00 0 | Oo le See, al” | 0 | 2 ! [> < | 
01. |!LUN | Pp 1 G | Defect List | 
| | | | Format | 

Beh ep ee a ory Reserved I 
Oe he Reserved st—~—S a 
of ©. Reserved | 
66a fe ee eee Reserved = = 4 
Se te Reserved = | 
ne eee Allocation Length (MSB) | 
o | ©. Allocation Length (LSB) | 
Gere ee ee a Control Byte ~~ | 


Figure 3-39 Read Defect Data command descriptor 


Defect List Format | 
Byte 01, bits 0, 1, and 2 of the Read Defect Data command descriptor 
provides the controller with Defect List format information. Figure 3-40 
shows these formats. 


BYTE 01 
Bits: 1 0 Format: 
Xx X Block 
1 ce] 0 Bytes From Index 
1 0 1 Physical Sector 


Figure 3-40 Defect list formats 


A Defect List format request to the controller (except a format of 
cylinder, head, and sector) causes the controller to return the Defect List 
in the cylinder, head, and sector format with a Check Condition status and 
a Sense key of Recovered Error. 


When the P bit is set to one, the controller returns the primary defect 
list. When the G bit is set to one, the controller returns the growth defect 
list. The P and G bits can be set in any combination. When the bits are 
zero, the controller returns no list. 
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The host uses the Allocation Length to determine the maximum 
number of defects returned. The controller does not return defect data if 
the Allocation Length is zero. 


The controller terminates the Data-In phase when the Allocation 
Length transfers, or when all available defect data transfers to the host, 
whichever is less. 


Figure 3-41 provides the Defect List Header information . 


| BIT | 
Lee te Oe A i sd a aD 
BYTE ===S=s=S===SSsSSSSSsSSSSssrsSrsSresr esses SSS SSS SST 
00 6 |6|)—l6 Reserved | 
O01 | Reserved | Pp | @G& | Defeet List 
| | | | Format 
02 | Defect List Length (MSB) | 
03 | Defect List Length (LSB) | 


cre re a ae ee re a a ee re ce re er re a ee a re a oe ee a a ee ee 
ee ee ee ee ee ee a ee Ee SE ES 


Figure 3-41 Defect list header 


Byte 01, bits 0, 1, and 2 are defined in Figure 3-40. The Defect List 
Format and bits P and G indicate the Defect List that the controller 
actually returns. The length of each defect descriptor is eight bytes in the 
following format: 


e Cylinder = Three Bytes 
e Head = One Byte 
e Sector = Four Bytes 


The Defect List Length specifies the total length in bytes of the defect 
descriptors that follow. 


If the Allocation Length of the command descriptor is too short to 
transfer all of the defect descriptors, the Defect List Length is not 
adjusted to reflect the truncation. A Check Condition status is not created 
by the controller. The defect deseriptors may, or may not, be sent in 
ascending order. 
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WRITE BUFFER (3B) 


3-50 


This command is used with the Read Buffer command as a diagnostic 
function to test the controller’s data buffer memory and the SCSI bus 
integrity. While this command executes, there is no access to the medium. 
Figure 3-42 shows the command descriptor. 
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Figure 3-42 Write Buffer command descriptor 


The Byte Transfer Length specifies the maximum number of bytes 
transferred to, and retained in the controller’s buffer. The Byte Transfer 
Length contains a four-byte header, followed by the Write Buffer data. 


A Byte Transfer Length of zero indicates that the controller does not 
transfer the Write Buffer header and Write Buffer data. This condition 
does not create a Check Condition status. Controllers with only internal 
buffers can transfer a maximum of 1042-bytes of data (four-bytes of 
header and a maximum of 1038-bytes of Write Buffer data). Controllers 
with external buffers can transfer a maximum of 2066-bytes. 


If the Byte Transfer Length is greater than the Available Length that 
the Read Buffer command reports, the controller creates the Check 
Condition status and a Sense key of Illegal Request. In this case, data is 
not transferred from the host. A request for a Byte Transfer Length that 
is less than the Available Length is not an error. 
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READ BUFFER (3C) 


This command is used with the Write Buffer command as a diagnostic 
function to test the controller’s data buffer memory and the SCSI bus 
integrity. While this command executes, there is no access to the medium. 
Figure 3-438 shows the command descriptor. 
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Figure 3-43 Read Buffer command descriptor 


The Allocation Length specifies the maximum number of bytes the 
host allocates for returned data. The Allocation Length contains a 
four-byte header, followed by the Read Buffer data. 


An Allocation Length of zero indicates that the Read Buffer header 
and Read Buffer data are not transferred. This condition does not create a 
Check Condition status. The host uses the data for comparison with the 
data pattern sent during the Write Buffer command. Controllers with 
only: internal buffers can transfer a maximum of 1042-bytes of data 
(four-bytes of header and a maximum of 1038-bytes of Write Buffer data). 
Controllers with external buffers can transfer a maximum of 2066-bytes. 


If the Allocation Length is greater than the Available Length, the 
Available Length transfers to the host. A request for an Allocation Length 
that is less than the Available Length is not an error. 


The controller terminates the Data-In phase when the Allocation 
Length transfers, or when the Available Length transfers to the host, 
whichever is less. 
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Figure 3-44 provides the Read Buffer Header information. 
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00 | Reserved | 

Ol | Reserved | 

02 || Available Length (MSB) | 

03 | Available Length (LSB) | 


Figure 3-44 Read Buffer header 


The following steps are recommended to prevent corruption of the 
controller’s Read Buffer by another host: 


@ The host issues the Reserve Unit command to all logical units of a 
controller before issuing the Write Buffer command. 

e The host issues the Release Unit command after completing the Read 
Buffer command. 
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NCR DIAGNOSTIC COMMANDS 


The controller issues the NCR diagnostic commands as a sub-function of the 
SCSI CCS Send Diagnostic (1D) command. The controller returns the NCR 
diagnostic command results with the SCSI CCS Receive Diagnostic Result 
(1C) command. 


The following diagnostic functions do not access data areas on the disk 
drive. The functions execute with other host commands concurrently. 


e (DO) Diagnostic Inquiry 

e (D3) Unit Test 

e (D5) Write Data 

e (D6) Read Data 

e (D7) Write with Check Bytes 
e (D8) Read with Check Bytes 
e (D9) Address Convert 


The Write Data, Read Data, Write with Check Bytes, and Read with 
Check Bytes commands are for fixed disk:drive maintenance use only. 
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DIAGNOSTIC INQUIRY (DO) 


This command instructs the controller to assemble and return 64 bytes of 
information about the designated unit. The data returns in the Data field 
of the Receive Diagnostic Result file. Figure 3-45 defines the Diagnostic 


Inquiry field. 


12 


14 


16 
30 


34 


20 


identification 

Data buffer size (521 bytes) 
Ram buffer size 

Last physical block address 


Maintenance area (Fixed drive) 


Start of the physical block address 


Maintenance area (Fixed drive) 


Length in blocks (Block size defined 
by controller Read Capacity commands.) 


Check byte block size (Fixed drive) 


Checked Record bytes + Check byte = 521 
Reserved. Always zero. 


Alternate Track Area Start address 
(Fixed drive) 


Alternate Track Area Length in blocks 
(Fixed drive) 


Number of cylinders (physical) 
Number of heads/cylinders 
Number of logical blocks/tracks 


Not defined. Always zero filled. 


Figure 3-45 Diagnostic inquiry data fieid 
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TEST BUFFER (D1) 


This command instructs the controller to transfer data from the host 
memory to its internal sector buffer. Upon completion of this data 
transfer, the controller sets an internal flag to identify the Test Buffer 
command and the host sending it. 


If the controller writes to this buffer with any other data transfer 
command, the internal Test Buffer command flag resets. The controller 
samples this flag when executing the ensuing Receive Diagnostic Result 
command to verify that the original data buffer was overwritten. Byte 00 
of the Receive Diagnostic Result sets to one if the original data is 
overwritten. The Test Buffer data is returned to the host for comparison. 


The maximum length of data allowed to transfer is 1042 bytes for 
internal buffers and 2066 bytes for external buffers. Data lengths 
exceeding this maximum length cause an Illegal Request Sense key to 
return in the Sense field of the Receive Diagnostic Result file. 


UNIT TEST (D3) 


This command causes the controller to perform a series of diagnostic tests 
to verify the functional integrity of the controller and the addressed 
logical unit (the disk drive). 


If a failure occurs during execution of any of these tests, an Error 
Sense key returns in the Receive Diagnostic Result file associated with the 
diagnostic function. | 


WRITE DATA/MAINTENANCE (D5) 


This maintenance command for fixed disk drives instructs the controller 
to transfer data from the host memory to the controller-identified 
maintenance area cylinder of the addressed logical unit. 


If errors occur during execution, the controller does not perform any 
error recovery procedures. The Returned status and Sense information 
identify the error type. 


The physical block address is an offset in the maintenance area (the 
start of the maintenance area is zero). The maximum length of the data 
transferred is identified in the Diagnostic Inquiry Field. If the data 
length exceeds the maintenance area block length, an Illegal Request 
Sense key returns in the Sense field of the Receive Diagnostic Result file. 
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READ DATA/MAINTENANCE (D6) 


This maintenance command for fixed disk drives instructs the controller 
to transfer data from the maintenance area of the addressed logical unit 
to the host memory. 


If errors occur during execution, the controller does not perform any 
Read retries or alternate assignments. When a data error occurs,. the 
controller performs the error correction procedure and transfers the data 
to the host. If the error correction is performed, the Sense field of the 
Receive Diagnostic Result file indicates whether a correctable or 
uncorrectable error occurred. 


The physical block address is an offset in the maintenance area. The 
maximum length of the data transferred is identified in the Diagnostic 
Inquiry Field. If the data length exceeds the maintenance area block 
length, an Illegal Request Sense key returns in the Sense field of the 
Receive Diagnostic Result file. 


WRITE WITH CHECK 
BYTES/MAINTENANCE (D7) 


This maintenance command for fixed disk drives instructs the controller 
to transfer data from the host memory to one block of the maintenance 
area. This data includes all data bytes contained in the Checked Data 
field, as well as the Check bytes. 


If errors occur during execution, the controller does not perform error 
recovery procedures. The returned Sense field of. the Receive Diagnostic 
Result file identifies the error. . 


The physical block address is an offset into the maintenance area. The 
total length of data bytes transferred is identified in the Diagnostic 
Inquiry field. 
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READ WITH CHECK 
BYTES /MAINTENANCE (D8) 


This maintenance command for fixed disk drives instructs the controller 
to transfer data from a block of the maintenance area to the host memory. 
This data includes all data bytes contained in the Checked Data field, as 
well as the Check bytes. This command returns SLI, data, and ECC bytes 
to the user. 


If errors occur during execution, the controller does not perform error 
recovery procedures. The returned Sense field of the Receive Diagnostic 
Result file identifies the error. 


The physical block address is an offset into the maintenance area. The 
total length of data bytes transferred is identified in the Diagnostic 
Inquiry field. 


ADDRESS CONVERT (D9) 


This command causes the controller to convert the user’s logical block 
address to a physical block address of the device. The user’s logical block 
address is given in the Send Diagnostic file, and the physical block 
address returns as data in the Receive Diagnostic Result file. 


SEEK TO PHYSICAL BLOCK ADDRESS 
(E4) 


This command instructs the controller to position the heads of a selected 
disk unit to the cylinder identified by the physical block address given in 
the Send Diagnostic file. 


The controller reads an address field from the disk to verify the Seek 
function. This command causes Seeks to execute for the entire disk area 
rather than limiting them to the user’s area (logical address). . 
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WRITE DATA (E5) 


This command instructs the controller to transfer data from the host 
memory to the physical block address specified in the Send Diagnostic 
file. A write to the controller cylinder is not allowed. 


If errors occur, the controller does not perform error recovery 
procedures. The Sense field returned in the Receive Diagnostic Result file 
identifies the error type. 


_ Some special conditions exist when addressing the disk with a 
physical addressing function. Included are the addressing of defective 
sectors or tracks and addressing alternate sectors or tracks. When these 
conditions are encountered, the controller completes the data transfer and 
returns a Recoverable Error Sense key in the Sense field of the Receive 
Diagnostic Result file. 


Byte 12 of the Sense information is 00 (Hex) to indicate No Sense. 


Byte 18 of the Sense information is one of the following codes: 


SENSE INFORMATION 
Byte Code Meaning 
18 01 Defector sector or track addressed 


18 02 Alternate sector or track addressed 


Figure 3-46 Sense information 


Code 01 
If a defective sector or track is addressed, the controller transfers data 
to the alternate sector or track, then returns the 01 code. 

Code 02 
If alternate track or sector is addressed, the controller transfers the 
data to the alternate sector or track, then returns the 02 code. 
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READ DATA (E6) 


This command transfers data from any physical block address of the disk 
to the host memory. 


The controller follows the same procedure indicated in the Write Data 
command when finding an alternate sector or track. 


If errors occur, the controller does not perform any Read retries or 
alternate sector or track assignments. 


If the error occurs on a fixed disk drive, the controller performs the 
error correction procedure and transfers the data to the host. After the 
error correction is performed, the Sense field of the Receive Diagnostic 
Result file indicates whether a correctable or uncorrectable error 
occurred. 


WRITE WITH CHECK BYTES (E7) 


This command for fixed disk drives transfers data from the host memory 
to any physical block address on the disk except the controller cylinder. 
The data includes all data bytes in the Checked Data field and the Check 
bytes. 


The controller follows the same procedure indicated in the Write Data 
command when finding an alternate sector or track. 


READ WITH CHECK BYTES (E8) 


This command for fixed disk drives transfers data from any physical 
block address of the disk to the host memory. This data includes all data 
bytes in the Checked Data field and the Check bytes. 


The controller follows the same procedure indicated in the Write Data 
command when finding an alternate sector or track. 
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ADDRESS LOCATOR (E9) 

: This command converts the physical block address value to physical 
cylinder, head, and sector. The. physical block address (cylinder, head, and 
sector values) is returned in the data field of the following Receive 
Diagnostic Result command. 


The field contains the following data bytes: 


Bytes Length identification (MSB,LSB) 


0-1 2 Physical cylinder number 
2-3 2 Physical head number 
4-5 2 Physical sector number 


Figure 3-47 Address locator information 


WRITE FORMAT (EA) 


This command for fixed disk drives causes the controller to write format 
data to a specific track on the disk. The controller starts at Sector 0 and 
writes the entire track format with each Write Format command. The 
Send Diagnostic file contains the physical block address and the format 
data for the entire track. 


The format data must comply with the “Address format” section 
except that a 10th byte equal to zero is required. The controller verifies 
cylinder and head data before writing the format. 
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READ FORMAT (EB) 
| This command causes the controller to read and assemble format data 
from a specific track of the disk. This data transfers to the host memory 
and contains the format data, starting at Sector 0, for the entire track. 
The Block Address field of the Send Diagnostic file contains the physical 
block address of the designated track to read. 


The first 5 bytes of format data returned must comply with the 
“Address Format” section. In addition to the address field; the Read 
Format function also returns the following 5 bytes. 


BYTE FLAG=80H/04H FLAG=01H 

06 00 Alternate cylinder MSB 

07 00 Alternate cylinder LSB 

08 00 ; Alternate head 

09 0O Alternate sector 

10 Address ECC error indication 
oO No address ECC error 
FF Address ECC error 


Figure 3-48 Read format information 
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SCSI MESSAGES 


The controller supports the following SCSI messages: 


SCSI MESSAGES 


Code Message 

00 Command Complete 
02 Save Data Pointer 
03 Restore Pointers 

04 Disconnect 

05 Initiator-detected Error 
06 Abort 

07 Message Reject 

08 No Operation 

og Message Parity EREGE 
oc Bus Device Reset 


80-FF identify 


Figure 3-49 SCSI message codes 


COMMAND COMPLETE (00) 


The controller sends this message to the host to indicate that the command 
_ execution terminated and the Valid status was sent to the host. 


SAVE DATA POINTER (02) 


_ The controller sends this message to direct the host to save a copy of the 
data pointers that define the present state of the physical path for the 
currently attached logical unit. 


RESTORE POINTERS (03) 


The controller sends this message to direct the host to restore all pointers 
to the most recently saved state for the currently attached logical unit 
(LUN). 
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DISCONNECT (04) 
The controller sends this message to inform the host that a break will 
occur in the present physical path (the controller releases the Busy (BSY) 
line, causing a Disconnect). Later a Reconnect is required to complete the 
current operation. 


INITIATOR-DETECTED ERROR (05) 


The host sends this message to inform the controller that the host detected 
the occurrence of a re-tryable error. 


ABORT (06) 


The host sends this message to direct the controller to abort the specified 
command. 


MESSAGE REJECT (07) 


The controller or the host sends this message to indicate that the last 
message received was either inappropriate‘or not implemented. 


NO OPERATION (08) 


The host sends this message in response to a controller request for a 
message when the host does not currently have any other valid message to 
send. 


MESSAGE PARITY ERROR (09) 


The host sends this message to indicate that the last message received had 
a parity error. 


BUS DEVICE RESET (OC) 


A host sends this message to direct a controller to clear all current 
commands on that SCSI device. This message forces the SCSI device to an 
initial state with no operations pending for any host. 


3-63 


SCS/ CCS COMMANDS 


IDENTIFY (80-FF) 


The controller or host sends this message to establish the physical path 
connection between the controller and host for a particular logical unit 
(LUN). The message content is defined as follows: 


BIT 
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DEFINITION 
Aiways ON. Signifies “IDENTIFY’’ message. 


Host sets this bit to indicate the 
disconnect/reconnect capability. 


Reserved. 


Specifies LUN address in the controller. 


Figure 3-50 Identify message 
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COMPLETION STATUS 


The host system must always receive the Completion status before the 
Command Complete message is sent. Abnormal conditions encountered 
during command execution initiate a command termination and a 
Completion status message to the host. The Completion status is reported 
as one byte with the following bit conditions: 


Bit 0: Reserved (Always zero) 

Bit 1: Check Condition. Sense information available. 
Bit 2: Reserved (Always zero) 

Bit 3: Busy 

Bit 4: Reservation Conflict when ON with Bit 3 

Bit 5: Reserved (Always zero) 

Bit 6: Reserved (Always zero) 

Bit 7: Reserved (Always zero) 
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SENSE INFORMATION 


The Request Sense command returns Sense information to a host. The 
host initiates the Request Sense command after receiving a Check 
Condition in the Completion status. 


The controller returns the Extended Sense format to the host in 
response to the execution of the Request Sense command. The Valid bit 
(bit 7 of byte 00) in the format indicates that the Information field (bytes 
03-06) contains the block address associated with the Sense key in byte 02. 
If the Valid bit is not set, the Information field has no defined meaning. 
The table that follows provides Sense Format information. 
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| BIT = a 
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BYTE OO =. valid! 2 =| «1 =| «1 =| «0 1 0 | ol oO | 
0. | Reservea=00- J 

@@: lo 6 | 6 Gl Sensetkey. = OC 


03-06 | Information Bytes (MSB-LSB) | 


08-11 | Reserved = 00 | 


12 | Additional Sense Code 
13° | Reserved=00 ©. | 
14 | FRUFailed | 
18 | Field Pointer Valid | © (| 
lesiy.) “Pista Painter 
18 | Recovery Action | 
19 | Retry Count © | 
20-23 | Transfer Count (MSB-LSB) ~~! 
24 | Number of Alternate Sectors ~~ ‘| 


-| (Fixed Format/Reassign Blocks) | 


25 | Number of Alternate Tracks | 
| (Fixed Format/Reassign Blocks) | 


Figure 3-51 Sense format information 
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Key 
00 
01 


02 
03 
04 
05 
06 
07 
OB 


INFORMATION BYTES 


SCSI CCS COMMANDS 


The controller returns the Sense keys defined in the following table: 


SENSE KEYS 


Definition 
No Sense 


Recoverabie 
Error 


Not Ready 
Media Error 
Hardware Error 
\ilegal Request 
Unit Attention 
Data Protect 


Aborted Command 


Additional Sense Length 
00 


16 (18 to Format Unit or 
Reassign Blocks) 


00/16 
16 


16 


Figure 3-52 Sense keys information 


Bytes 03-06 contain the block address associated with the Sense key when 
the Valid bit in byte 00 is set. 


ADDITIONAL SENSE LENGTH 


This byte indicates the number of Sense bytes that follow byte 07. 


3-67 


SCSI CCS COMMANDS 


ADDITIONAL SENSE CODE 


This byte contains codes to aid the host in determining the nature of an 
error. The Additional Sense codes are defined in the following table: 


ADDITIONAL SENSE CODES 


Code Definition Related Sense key 
00 No Secondary Error Code Recovered error 
03 Write Fault Hardware error 

06 No Track Zero found Hardware error 

08 Logical Unit Comm Failure Medium error 

10 1D CRC or ECC error Hardware error or 


Medium error 


11 Unrecovered Read error Medium error 
of data blocks 


12 No Address Mark found Medium error 
in ID field 
15 Seek Positioning error |. = Hardware error or 


Medium error 


17 Recovered Read data with = Recovered error 
Target's Read retries 
(not with ECC) 


18 Recovered Read data with Recovered error 
Target's ECC correction 
(not with retries) 


19 Defect List Error Medium error 

24 illegal Fieid in Illegal request 
command descriptor . 

26 Illegal Field in legal request 
Parameter List 

2A Mode Select Parameters Unit attention 
changed 

32: No Defect Spare | Medium error 


location available 


Figure 3-53 Additional sense code information (1 of 2) 
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ADDITIONAL SENSE CODES 


Code Definition Related Sense key 

42 Power On diagnostic Hardware error 
failure 

43 Message Reject error Hardware error or 


Aborted command 


44 Internal controller Hardware error or 

error Aborted command 

45 Seiect/Reselect failed Hardware error or 
Aborted command 

47 SCSI I/F parity error Hardware error or 
Aborted command 

48 Initiator-detected error Hardware error or 
Aborted command 

49 Inappropriate or Hardware error or 

illegal Message Aborted command 

80 Data field not found Medium error 

81 Data buffer parity error Hardware error 

82 Buffer not available ‘ “Hardware error 

83 Controller cylinder error Medium error 

84 Drive unformatted Not ready 

85 Divide error Hardware error 


Figure 3-53 Additional sense code information (2 of 2) 


FIELD REPLACEABLE UNIT FAILED 


If the FRU (controller) failed during power-up diagnostics, this field 


contains the error code. 


FIELD POINTER VALID 


This field contains a 80 (Hex) if the Field Pointer is valid; otherwise, the 


field is 00. 


FIELD POINTER 


If valid, this field contains the most significant byte address for the first 
field in error. 
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RECOVERY ACTION 


This byte contains a code describing controller action taken to recover 
from the error. The following table defines the Recovery Action codes: 


RECOVERY ACTION CODES 


Code Definition 

00 ; No action 

01 Defective sector/track addressed 
02 Alternate track addressed 

03 Retries 

04 ECC correction 

05 Alternate sector/track assigned 
06 Alternate assigned/one spare left 
07 Alternate assigned/no spares left 
08 Alternate needed/ 6 spares left 
09 None-recoverable error 


Figure 3-54 Recovery action code information 


RETRY COUNT 


This byte indicates the number of retries the controller performed before 
terminating the command. 


TRANSFER COUNT 


- These bytes contain the number of blocks transferred to/from the host. 


NUMBER OF ALTERNATE SECTORS 


This byte contains the number of alternate-sectors assigned. 


NUMBER OF ALTERNATE TRACKS 


This byte contains the number of alternate-tracks assigned. 
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ERROR RECOVERY 


The controller automatically performs the following error recovery 
procedures for LUNs 00, 01, 02, and 03 without host intervention. 


e During a Write or Read operation, if the controller fails to find a 
sector after 16 attempts, the controller terminates with a Check 
Condition status and a Media Error Sense key in the Sense data. 

e Data error recovery for all commands except the Write and Verify 
and the NCR Write and Verify commands are restricted to multiple 
retries and ECC correction. 


DISK DRIVE INTERFACE 


The controller interfaces to the fixed disk drives through the 
daisy-chained command cable and radially-connected data cables. 


COMMAND CABLE 


The 34-pin command cable supplies command information to the disk 
drives and receives drive status from the selected drive. The controller 
allows up to four daisy-chained disk drives to connect to the cable. 


DATA CABLES 


The controller allows a maximum of four 20-pin data cables, one for each 
disk drive. The cable maintains a high level of data integrity between the 
controller and the disk drive. 


TRACK FORMAT 


The tracks for both hard and soft sectors are formatted on the disk as 


follows: 
| SECTOR | SECTOR | | SECTOR | SECTOR | 


| re) | i -- N-1 | N | N - Varies 
| 


wwe ere ew wow wwe ewe woe w ae wwwewe ew ee wo eww ewe = 


The controller performs the Format Unit command independent of the 
host. The host system is not responsible for knowing the track format. 
This information is included only for use by the host diagnostic software. 
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& 
Sector Format 


-- | SPLICE 
| _| FIELD | BYTE 
ices tonsesons Es a eee oh ns tooneoS fale 


* Soft sector only 


+eoecewne +o werenwne +e ee pe ewe ocne town wne teow awnwa Peouwnanc a's paw wnnwnww + 
| | ADDR. | | PLO | ID | ADDR. | ADDR. | ADDR. | 
| ISG | MARK | PaD | SYNC | SYNC | FIELD | CRC | PAD | 
| * | * | FIELD | BYTE | | | | 
pa oe en we toe nw nnn om a toe wenne pw wee ne toeweewwnn Pe we we we ee we we ey + 
5 en teow weoe toscana canse 5 Poses tome en www wen + 
| WRITE | PLO | DATA | DATA | DATA | DATA | FORMAT 
| sync | SYNC | FIELD : ECC | PAD | SPEED 
+ 


SECTOR FORMAT DEFINITION 


FIELD VALUE 

ISG 12 bytes of zero - drive dependent 
Address Mark 3 bytes - soft sectors. only 

PAD 1 byte - soft sectors only 

PLO sync field 11 bytes - drive dependent 

1D Sync Byte 1 byte - value of “FE” 

Address Fieid 5 bytes - see Address Format section 
Address CRC 2 bytes 

Address Pad 2 bytes 

Write Splice 1 byte 

FLO Sync Field 11 bytes - drive dependent 

Data Sync Byte(1) 1 byte - value of “FE” 

Data Field 256, 512 or 1024 bytes 

Data ECC 7 bytes of plynomial code - see 


Error Detection and Correction Code 
Format section 


Data Pad 2 bytes 
Format Speed Tolerance 15 bytes of zero - drive dependent 


(1) Included in ECC caiculations. 


Figure 3-55 Sector format information 
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Address Format 
. The address field has the following 9 bytes of information: 


FIXED DISK DRIVE 
ADDRESS FIELD FORMAT 


Byte Address 

01 Cylinder Address MSB 
02 Cylinder Address LSB 
03 Head Number 

04 Logical Sector Number 
05 Flag Bytes 


80 Good Primary or Alternate-Sector 
O01 User-declared Defective Tract 
04 Alternate-Track 


Figure 3-56 Address format information 


Alternate And Defective Sectors 
The alternate-sector mode is chosen through the Mode Select command. 
The alternate-sector mode reduces the number of user sectors per track by 
one. 


If the user selects the Alternate Track Only option, no 
alternate-sectors are available. Defect Reassignment is through Alternate 
Track Assignment only. 


If the user selects the Alternate Sector/Alternate Track option, one 
alternate-sector on all user tracks is reserved. Therefore, a maximum of 
one defective sector is permitted per track. If more than one sector is 
found to be defective, then the controller assigns an alternate-track. 


An alternate-sector reassignment is permitted only during the Format 
Unit and Reassign Blocks commands. When a sector normally available to 
the user is defective, then determination is made as to whether the 
address field is still good. The address field is needed to format the bad 
sector as defective. If the address field is determined good, the sector is 
reformatted to a 77 (hex) sector number, indicating a defective sector. 
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Alternate And Defective Tracks 


A defective track must contain at least one good sector. The controller 
flags defective tracks‘in the address field of every sector on the track by 
setting the flag byte in the address fields to indicate one of the defective 
track status codes. The address of the alternate-track is contained in the 
first four bytes of the data field on the defective track. The first three of 
those bytes must contain the cylinder number and head number of the 
alternate-track in hex; the alternate-sector number is not significant in 
this case and should contain zero. A defective track will not point to 
another defective track as its alternate-track. 


Error Detection And Correction Code Format 
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The sector format includes seven Error Detection and Correction bytes 
that follow each Address field and Data field. The controller generates 
these ECC bytes for error detection and correction. The controller | 
generates the ECC bytes that follow the Address field during Format 
functions and those following the Data field during the Write Data 
functions. 


The following polynomial code generates the seven ECC bytes: 
(X22+1) (X11+X7+X6+X+1) (X12+X11+...X2+X+1) (XL1+X9+X7+X6+K5+X+1 ) 


This 56-bit ECC code detects 22-bit error bursts, and corrects burst 
errors up to 11 bits long. The ECC bytes that follow the Address field are 
for error detection only, and those following the Data field are for error 
detection and correction when a Read error occurs. 


USER INTERFACE 


CHAPTER 4 


USER INTERFACE 


INSTALLATION 
COMPONENT LOCATION 


The user interface consists of the following items: 


e An eight-position switch pack used for SCSI device ID selection and 
controller options 

e A four-position switch pack used for hardware options 

e LEDs to display error codes. All LEDs are located near the outer edge 
of the printed circuit board to facilitate accessibility 

e SCSI bus terminators 


The user interface components listed above are at the following 
locations: 


8-Bit 4-Bit 

Switch Switch LEDs 
Single-ended board U3 U16 CR2 
Differential board i 11F 111 (CR3) 


Figure 4-1 Component locations 
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PHYSICAL SIZE 
Pa The ESDI Disk Controller boards have the following nominal 
measurements: 


e ADP-47-03 Single-ended SCSI (4.0 x 6.25 x .062 inches) 
e ADP-47-04 Differential SCSI (5.75 x 7.8 x .062 inches) 


SCSI BUS TERMINATORS 


Each controller contains terminator resistors. If the controller is the last 
physical device on the daisy-chained SCSI bus, the terminator resistors 
must be in place. If the controller is not an end device, remove the 
terminator resistors. Removal of the terminators does not effect any other 
operation. Refer to Figures 4-6 and 4-11 for the location of the terminator 
resistors. 


: USER INTERFACE 


TROUBLE-SHOOTING 


The controller board contains four status LEDs. These LEDs display 
power-up diagnostic results as error codes. Listed below are the error 
codes. 


HEX 

CODE DESCRIPTION 

01 8088 Power-up error 

02 ROM checksum error 

03 RAM error 

04 SDC interrupt error 

05 SDC SCSI control error 

06 SDC DMA control error 

07 SDC data buffer error 

08 SDC Control Store RAM error 
09 SDC diagnostic control error 
OA SDC disk control error 

OB SDC ECC control error 

oc - §DC CRC control error 

OD Differential chip error 

OE Passed power-up diagnostics 


Figure 4-2 LED error codes 


PREPARING THE BOARD 


The controller board contains two switch packs, one four-position switch 
pack and one eight-position switch pack. These switches control the 
options of the controller and its SCSI identification. 


USER INTERFACE 


EIGHT-POSITION SWITCH PACK 
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The controller uses the following switch positions on the eight-position 
switch pack to select diagnostic options and the SCSI ID. 


SWITCH 1 2 3 4 5 6 7 8 

Not used OFF 

No flex support OFF 

Single-ended SCSI . ON 

Differential SCSI OFF 

Continue on error OFF OFF 

Loop on error OFF ON 

Halt on error ON OFF 

RAM read loop ON ON 

SCSI 1D 0 . OFF OFF ~— OFF 

SCSI ID 1 OFF OFF ON 

SCSI 1D 2 it, OFF ON OFF 

SCSI ID 3 OFF ON ON 
- SCSIID 4 ON OFF OFF 

SCSI ID 5 * ON OFF ON 

SCSI ID 6 ON * ON OFF 

SCSI ID 7 a ON ON ON 


Figure 4-3 Ejight-position switch pack 
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FOUR-POSITION SWITCH PACK 


The controller uses the Power/Fail circuit to protect the disk media in the 
event a power failure occurs. After a power failure occurs, the Power/Fail 
circuit performs a board Reset. The Power/Fail switch on the 
four-position switch pack controls how the controller uses the Power/Fail 
circuit. If the power supply has a Power/Fail circuit, connect it to pin-2 of 
the power connector and position the Power/Fail switch accordingly. If 
the power supply does not have a Power/F ail circuit, use the Power/Fail 
circuit on the controller board by positioning the Power/Fail switch 
accordingly. 


The following hardware options are selectable on the Single-ended 
controller board by the switches on the four-position switch pack. 


SINGLE-ENDED 
Option Switch 1 2 3 4 
Factory testing ON ON ON 


ON connects 

external 

Power/Fail to 

pin-2 of J1 ON 


OFF for 

Power/Fail 

from the 

controller OFF 


Figure 4-4 Four-position switch pack 
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The following hardware options are selectable on the Differential 
controller board by the switches on the four-position switch pack. 


DIFFERENTIAL CONTROLLER 


OPTION SWITCH 1 2 3 4 
Power/Failure form controller ON OFF 

Power/Failure at pin-2 OFF ON 

Differential Sense enabled ON © 

Switch 4 is not used OFF 


ON, ON and OFF, OFF are illegal switch combinations for switches 1 
and 2. 


Figure 4-5 Differential controller, four-position switch pack 
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SINGLE-ENDED 
CONTROLLER BOARD | 


ems itetiod 2 ESDI S.E. 


32K x 8 EPROM 


[ SCst ~~ j{scsr | | 
> TERM ||, TERM [oni = 


ae | yay. 235. 


oO SCSI (S.E.) J2 


1 
O 1, COMMAND 3 2 UNIT 0 Jus 


SCSI TERMINATOR 
POWER FUSE (1.5 AMP) 


Figure 4-6 NCR ADP-47-03 ESDI Single-ended Controller board 
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SINGLE-ENDED BOARD 
CONNECTORS 


J1 - POWER CONNECTOR 


PIN 
1 


2 
3 
4 


DESCRIPTION 


Not connected 
Power/Fail 
Ground 


+5 Volts de 


Figure 4-7 Power connector pin-out 


J2 - SINGLE-ENDED SCSI BUS 


CONNECTOR 

PIN DESCRIPTION PIN 
1 Ground 2 
3 Ground 4 
5 Ground 6 
7 Ground 8 
9 Ground 10 
11 Ground 12 
13 Ground 14 
15 Ground 16 
17 Ground 18 
19 Ground 20 
21 Ground 22 
23 Ground 24 
25 Open 26 
27 Ground 28 
29 Ground 30 
31 Ground 32 
33 Ground 34 
35 Ground 36 
37 Ground 38 
39 Ground 40 
41 Ground 42 
43 Ground 44 
45 Ground 46 
47 Ground 48 
49 Ground 50 


DESCRIPTION 


Figure 4-8 Single-ended SCSI connector pin-out 


J3 - FIXED DISK COMMAND CABLE 


DESCRIPTION 


Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 


10 
12 
14 
16 
18 
20 
22 
24 
26 
28 
30 
32 
34 
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DESCRIPTION 


HDSEL3/ 
HDSEL2/ 
WRITEGATE/ 
CSTAT/ 
TACK/ 
ATTEN/ 
HDSELO/ 
SECTOR/AMF/ 
HDSEL1/ 
INDEX/ 
READY/ 
TREQ/ 
DRVSELO/ 
DRVSEL1/ 
DRVSEL2/ 
RDGATE/ 
CDATA/ 


Figure 4-9 Singie-ended board command cable pin-out 


J4, J5, J6, & J7- UNIT O, 1,2,&3 
FIXED DISK DATA CABLE 


DESCRIPTION 


DRVSELDX/ 
CMD CMP/ 
Ground 
WRCLK+ 
Ground 
REFCLK- 
WDATA+ 
Ground 
RDATA+ 
Ground 


10° 
12 
14 
16 
18 
20 


DESCRIPTION 


SECTOR/AMF/ 
AME/ 

Ground 
WRCLK- 
REFCLK+ 
Ground 
WDATA- 
Ground 
RDATA- 
INDEX/ 


Figure 4-10 Single-ended board data cable pin-out 
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DIFFERENTIAL 


CONTROLLER BOARD 


SCSI TERMINATOR 
POWER FUSE (1.5 AMP) 


— 


3 _UNITO YN UNAT 2 
J4 


—_ 


UNIT 1 ¥ 
= 9s 


SCSI (DIFF) 


w 
—] 


DRIVE SELECT 


CR3 
by LED| 
19 Soa. O___Je22 c230_.. 1] 8421 
ot BE Per 9 : 


NCR ADP-47-04 ESDI Differential Controller board 


Figure 4-11 
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DIFFERENTIAL BOARD 
CONNECTORS 


J1 - POWER CONNECTOR 


PIN DESCRIPTION 


1 Not connected 
2 Power/Fail 

3 Ground 

4 +5 Volts de 


Figure 4-12 Power connector pin-out 


J2 - DIFFERENTIAL SCSI BUS 


CONNECTOR 
PIN DESCRIPTION PIN DESCRIPTION 
1 Not connected — 2 Ground 
3 +DBO 4 - -—DBO 
5 +DB1 6 -DB1 
7 +DB2 8 -DB2 
9 +DB3 10 -DB3 
11 +DB4 12 -DB4 
13 +DB5 14 -DB5 
15 +DB6 16 -DB6 
17 +DB7 18 -DB7 
19 +DBP 20 -DBP 
21 DIFFSENS 22 Ground 
23 Ground 24 Ground 
25 TRMPWR 26 TRMPWR 
27 Ground 28 Ground 
29 +ATN 30 -ATN 

oe 31 Ground 32 Ground 

i 35 +BSY 34 -BSY 

37 +ACK 36 -ACK 
39 +RST 38 -RST 
41 +MSG 40 -MSG 
43 +SEL 42 -SEL 
45 +C/D 44 -C/D 
47 +REQ 46 -REQ 
49 +1/0 48 1/0 
49 Ground 50 Ground 


Figure 4-13 Differential SCS! connector pin-out 
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J3 - FIXED DISK COMMAND CABLE 


= 
2 


on aw — 


DESCRIPTION 


Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 
Ground 


DESCRIPTION 


HDSEL3/ 
HDSEL2/ 
WRITEGATE/ 
CSTAT/ 
TACK/ 
ATTEN/ 
HDSELO/ 
SECTOR/AMF/ — 
HDSEL1/ 
INDEX/ - 
READY/ 


. TREQ/ 


DRVSELO/ 
DRVSEL1/ 
DRVSEL2/ 
RDGATE/ 
CDATA/ 


Figure 4-14 Differential board command cable pin-out 


J4, J5, J6 & J7 - UNIT O, 1, 2 & 3 FIXED 


DISK DATA CABLE 


PIN DESCRIPTION PIN DESCRIPTION 
1 DRVSELDX/ 2 SECTOR/AMF/ 
3 CMD CMP/ 4 AME/ 

5 Ground 6 Ground 

7 WRCLK+ 8 WRCLK- 

9 Ground 10 REFCLK+ 

11 REFCLK- 12 Ground 

13 WDATA+ 14 WDATA- 

15 Ground 16 Ground 

17 RDATA+ 18 RDATA- 

19 Ground 20 INDEX/ 


Figure 4-15 Differential board data cable pin-out 


